程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Struts從零開始三、連接數據庫實例

Struts從零開始三、連接數據庫實例

編輯:關於JAVA

效果圖:

我們以結果為導向,首先大家先看看要完成的效果圖,對接下來要做的事情有個清晰的認識。

1、如圖鍵入:

顯示結果如下圖:

如果您輸入的是不合法的話,則如下圖:

修改步驟:

A、數據源配置

在struts-config.xml文件中有一元素是用來配置應用所需要的數據源,數據源負責建立和特定數據庫的連接,許多數據源采用連接池的機制實現,即提高了數據庫的訪問性能。具體代碼片段如下所示:

<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數據庫的連接。元素的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),所以實際操作中建議不要這麼做。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved