首页 > 开发 > JSP > 正文

Struts初级教程(3)-结合数据库应用

2020-05-06 19:54:09
字体:
来源:转载
供稿:网友
这一节我们开始用Struts结合数据库设计程序,主要将上一节的程序略做修改,如下所示:

效果图:


显示结果如下图:





如果您输入的是不合法的话,则如下图:


程序修改步骤:

A、数据源配置
     在struts-config.xml文件中有一<data-sources>元素是用来配置应用所需要的数据源,数据源负责建立和特定数据库的连接,许多数据源采用连接池的机制实现,即提高了数据库的访问性能。代码片段如下:

<data-sources>
    <data-source key="DataSource" type="org.apache.commons.dbcp.BasicDataSource">
        <set-property property="driverClassName" value="com.mysql.jdbc.Driver" />
        <set-property property="url" value="jdbc:mysql://localhost:3306/struts1_login"/>
        <set-property property="username" value="root"/>
        <set-property property="password" value="5ihpp1314"/>
    </data-source>
</data-sources>
上面这段代码配置了与MySQL数据库的连接。<data-source>元素的key是一个别名,用于在应用程序中去的一个连接,元素type用来指定数据源的实现类。上面使用的是Apache软件组织提供的DBCP数据源。所以你必须导入commons-dbcp.jar、commons-pool.ar、struts-legacy..jar这三个包和MySQL的驱动包:mysql-connector-java-5.0.5-bin.jar。
配置了数据源后,就可以在Action中访问数据源了。

代码如下所示:
//获取Servlet上下文对象
ServletContext ctx = servlet.getServletContext();
//获得数据源
DataSource ds = (DataSource) ctx.getAttribute("DataSource");
//获取数据库的连接
Connection conn = ds.getConnection();

B、修改Action
Action将取得数据源,得到一个数据库的连接,把页面传近来的用户名和密码,通过jdbc与数据库进行对比,如果存在转到“success.jsp”并显示其名称,否则到错误页面。

具体实现代码如下所示:
public class LoginAction extends Action {
       public ActionForward execute(ActionMapping actionMapping,
                                        ActionForm actionForm, HttpServletRequest request,
                                            HttpServletResponse response) {
    LoginActionForm loginform = (LoginActionForm) actionForm;
    String username = loginform.getUsername();
    String userpass = loginform.getUserpass();
    ServletContext ctx = servlet.getServletContext();
    DataSource ds = (DataSource) ctx.getAttribute("DataSource");
    boolean flag = false;
    String sql = "select * from user where username='" + username
                            + "' and password='" + userpass + "'";
    try {
            Connection conn = ds.getConnection();
            Statement st = conn.createStatement();
            ResultSet rs = st.executeQuery(sql);
                while (rs.next()) {
                    flag = true;
                }
        } catch (Exception e) {
            e.printStackTrace();
        }
            String actionpath = "";
        if (flag) {
            request.setAttribute("username", username);
            actionpath = "success";
              } else {
            actionpath = "error";
              }
            return actionMapping.findForward(actionpath);
        }
}

C、修改页面
如果登录成功,通过EL显示用户名。
具体代码如下:
<%@ page contentType="text/html; charset=GBK" %>
%@taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %
<html>
    <head>
        <title>
            success
        </title>
    </head>
    <body bgcolor="#ffffff">
        <h1>success.jsp demo</h1>
        <br>
        <h1>welcome
            <font color="red" size="8"><bean:write name="username"/></font>
            here,thanks
        </h1>
    </body>
</html>
引入struts的标签,输出用户名称。

提示:使用数据源配置,让struts来管理不是太妥当,数据的相关操作应该属于持久层的管理,不应该由上一层管理(Controller)。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表