Struts初级教程(3)-结合数据库应用_JSP教程
教程Tag:暂无Tag,欢迎添加,赚取U币!
推荐:Struts初级教程(2)-避免出现乱码Jsp开发中经常出现中文 乱码问题,所以必须提前 处理。前面例子中,只要用户名和密码都是123,才返回成功的页面。为了处理中文,我们设定判断只有用户名是张三才登陆成功。 既然是中文乱码处理,页面的用户输入就是中文了,相应的action的if处理也要变成:if(u
这一节我们开始用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)。
分享:Struts初级教程(1)-用户登录实例本教程从易用,实用的目的出发,模拟完成实际开发中常用的模块,让大家能快速上手struts,下面我们正式开式吧。 Jsp的Struts是一个基于SunJ2EE平台的MVC框架,主要是采用Servlet和JSP技术来实现的。 Struts把Servlet、JSP、自定义标签和信息资源(messagereso
相关JSP教程:
- jsp response.sendRedirect不跳转的原因分析及解决
- JSP指令元素(page指令/include指令/taglib指令)复习整理
- JSP脚本元素和注释复习总结示例
- JSP FusionCharts Free显示图表 具体实现
- 网页模板:关于jsp页面使用jstl的异常分析
- JSP页面中文传递参数使用escape编码
- 基于jsp:included的使用与jsp:param乱码的解决方法
- Java Web项目中连接Access数据库的配置方法
- JDBC连接Access数据库的几种方式介绍
- 网站图片路径的问题:绝对路径/虚拟路径
- (jsp/html)网页上嵌入播放器(常用播放器代码整理)
- jsp下显示中文文件名及绝对路径下的图片解决方法
- 相关链接:
- 教程说明:
JSP教程-Struts初级教程(3)-结合数据库应用。