国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JSP > 正文

Struts初級教程(3)-結合數據庫應用

2024-09-05 00:17:22
字體:
來源:轉載
供稿:網友
這一節我們開始用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)。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 綦江县| 田东县| 秦皇岛市| 大丰市| 蓝田县| 民勤县| 兰西县| 山阴县| 石台县| 高尔夫| 会理县| 鄄城县| 新巴尔虎右旗| 贡嘎县| 德州市| 页游| 莲花县| 文昌市| 兴城市| 达州市| 财经| 扶余县| 东平县| 英超| 班玛县| 客服| 沙雅县| 普安县| 周口市| 增城市| 思南县| 无为县| 将乐县| 鲜城| 北碚区| 龙江县| 兴仁县| 顺义区| 通化县| 庆元县| 泽库县|