Struts初級教程(3)-結(jié)合數(shù)據(jù)庫應用_JSP教程
教程Tag:暫無Tag,歡迎添加,賺取U幣!
推薦:Struts初級教程(2)-避免出現(xiàn)亂碼Jsp開發(fā)中經(jīng)常出現(xiàn)中文 亂碼問題,所以必須提前 處理。前面例子中,只要用戶名和密碼都是123,才返回成功的頁面。為了處理中文,我們設定判斷只有用戶名是張三才登陸成功。 既然是中文亂碼處理,頁面的用戶輸入就是中文了,相應的action的if處理也要變成:if(u
這一節(jié)我們開始用Struts結(jié)合數(shù)據(jù)庫設計程序,主要將上一節(jié)的程序略做修改,如下所示:效果圖:

顯示結(jié)果如下圖:

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

程序修改步驟:
A、數(shù)據(jù)源配置
在struts-config.xml文件中有一<data-sources>元素是用來配置應用所需要的數(shù)據(jù)源,數(shù)據(jù)源負責建立和特定數(shù)據(jù)庫的連接,許多數(shù)據(jù)源采用連接池的機制實現(xiàn),即提高了數(shù)據(jù)庫的訪問性能。代碼片段如下:
<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數(shù)據(jù)庫的連接。<data-source>元素的key是一個別名,用于在應用程序中去的一個連接,元素type用來指定數(shù)據(jù)源的實現(xiàn)類。上面使用的是Apache軟件組織提供的DBCP數(shù)據(jù)源。所以你必須導入commons-dbcp.jar、commons-pool.ar、struts-legacy..jar這三個包和MySQL的驅(qū)動包:mysql-connector-java-5.0.5-bin.jar。
配置了數(shù)據(jù)源后,就可以在Action中訪問數(shù)據(jù)源了。
代碼如下所示:
//獲取Servlet上下文對象
ServletContext ctx = servlet.getServletContext();
//獲得數(shù)據(jù)源
DataSource ds = (DataSource) ctx.getAttribute("DataSource");
//獲取數(shù)據(jù)庫的連接
Connection conn = ds.getConnection();
B、修改Action
Action將取得數(shù)據(jù)源,得到一個數(shù)據(jù)庫的連接,把頁面?zhèn)鹘鼇淼挠脩裘兔艽a,通過jdbc與數(shù)據(jù)庫進行對比,如果存在轉(zhuǎn)到“success.jsp”并顯示其名稱,否則到錯誤頁面。
具體實現(xiàn)代碼如下所示:
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的標簽,輸出用戶名稱。
提示:使用數(shù)據(jù)源配置,讓struts來管理不是太妥當,數(shù)據(jù)的相關(guān)操作應該屬于持久層的管理,不應該由上一層管理(Controller)。
分享:Struts初級教程(1)-用戶登錄實例本教程從易用,實用的目的出發(fā),模擬完成實際開發(fā)中常用的模塊,讓大家能快速上手struts,下面我們正式開式吧。 Jsp的Struts是一個基于SunJ2EE平臺的MVC框架,主要是采用Servlet和JSP技術(shù)來實現(xiàn)的。 Struts把Servlet、JSP、自定義標簽和信息資源(messagereso
相關(guān)JSP教程:
- jsp response.sendRedirect不跳轉(zhuǎn)的原因分析及解決
- JSP指令元素(page指令/include指令/taglib指令)復習整理
- JSP腳本元素和注釋復習總結(jié)示例
- JSP FusionCharts Free顯示圖表 具體實現(xiàn)
- 網(wǎng)頁模板:關(guān)于jsp頁面使用jstl的異常分析
- JSP頁面中文傳遞參數(shù)使用escape編碼
- 基于jsp:included的使用與jsp:param亂碼的解決方法
- Java Web項目中連接Access數(shù)據(jù)庫的配置方法
- JDBC連接Access數(shù)據(jù)庫的幾種方式介紹
- 網(wǎng)站圖片路徑的問題:絕對路徑/虛擬路徑
- (jsp/html)網(wǎng)頁上嵌入播放器(常用播放器代碼整理)
- jsp下顯示中文文件名及絕對路徑下的圖片解決方法
- 相關(guān)鏈接:
- 教程說明:
JSP教程-Struts初級教程(3)-結(jié)合數(shù)據(jù)庫應用
。