原文链接:http://blog.sina.com.cn/s/blog_75f397940101if83.html
Java struts 框架编程
Struts
Struts编程框架:
1-在myeclipse软件中建立一个web
2-建立完web
Struts
Struts
ActionServlet
URL
Base
Default
点击Finish完成struts库文件的导入。
导入成功后的文件结构如下:
struts-config.xml:配置文件,在这里新建action,form,jsp
validator-rules.xml:validator
其余以struts开始的都是struts标签的配置文件。我们只需要使用即可,当然也可以自我进行配置自己特定的标签。
一个实例演示struts:学生学籍查询(模糊查询)
需求分析:查询学生学籍,要涉及到数据库的操作,要涉及到页面的表单操作。
输入学生名字,点击模糊查询。会返回查询结果。
这里目的只是显示struts的知识点。页面操作等详细细节不做过多要求。
在以上的基础上,
1. 在temp包下新建QueryForm.java和QueryAction.java
2.在src下新建bean文件包,com.bean,新建StudentBean.java文件
3.在src下新建dao文件包,com.dao,新建StudentDao.java文件
4. WebRoot下新建queryform.jsp文件、result.jsp文件、index.jsp可以做导航页面。
StudentBean.java文件:
package com.bean;
//封装一个学生的资料
public class StudentBean {
private String stuId;
private String stuName;
private String stuSex;
private String stuBir;
private String stuAdd;
public String getStuId() {
return stuId;
}
public void setStuId(String stuId) {
this.stuId = stuId;
}
public String getStuName() {
return stuName;
}
public void setStuName(String stuName) {
this.stuName = stuName;
}
public String getStuSex() {
return stuSex;
}
public void setStuSex(String stuSex) {
this.stuSex = stuSex;
}
public String getStuBir() {
return stuBir;
}
public void setStuBir(String stuBir) {
this.stuBir = stuBir;
}
public String getStuAdd() {
return stuAdd;
}
public void setStuAdd(String stuAdd) {
this.stuAdd = stuAdd;
}
}
StudentDao.java文件:
package com.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import com.bean.StudentBean;
public class StudentDao {
private Connection conn = null;
public void initConnection() {
try {
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
conn = DriverManager
.getConnection("jdbc:sqlserver://localhost:1433;"
+ " DatabaseName=学生学籍信息", "sa", "sa");
} catch (Exception e) {
}
}
public ArrayList queryStuByName(String sname) {
ArrayList stus = new ArrayList();
String sql = "select 学号,姓名,性别,出生年月," + "家庭住址 from 学籍表 where 姓名 like '%"
+ sname + "%'";
//System.out.println("StudentDao.java中queryStuByName函数sname="+sname);
try {
this.initConnection();
ResultSet rs = conn.createStatement().executeQuery(sql);
while (rs.next()) {
StudentBean stu = new StudentBean();
stu.setStuId(rs.getString("学号"));
stu.setStuName(rs.getString("姓名"));
stu.setStuSex(rs.getString("性别"));
stu.setStuBir(rs.getString("出生年月"));
stu.setStuAdd(rs.getString("家庭住址"));
stus.add(stu);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
this.closeConnection();
}
return stus;
}
public void closeConnection() {
try {
if (conn != null) {
conn.close();
conn = null;
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
index.jsp文件:
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
This is my JSP page. <br>
<a href="queryform.jsp">学生学籍查询</a>
</body>
</html>
queryform.jsp文件:
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'queryform.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
查询表单 <br>
<form action="/Project02/query.do" method="post">
请您输入学生姓名:<input name="sname">
<input type="submit" value="模糊查询">
</form>
</body>
</html>
result.jsp文件:
<%@page import="com.bean.StudentBean"%>
<%@page import="com.dao.StudentDao"%>
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'queryform.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
返回结果页面
<br>
<%ArrayList stus =(ArrayList)request.getAttribute("stus"); %>
<table>
<tr>
<td>
学号
</td>
<td>
姓名
</td>
<td>
性别
</td>
<td>
出生年月
</td>
<td>
家庭住址
</td>
</tr>
<%
for(int i=0;i<stus.size();i++){
StudentBean stu=(StudentBean)stus.get(i);
%>
<tr>
<td>
<%=stu.getStuId() %>
</td>
<td>
<%=stu.getStuName() %>
</td>
<td>
<%=stu.getStuSex() %>
</td>
<td>
<%=stu.getStuBir() %>
</td>
<td>
<%=stu.getStuAdd() %>
</td>
</tr>
<%} %>
</table>
</body>
</html>
QueryForm.java文件:
package project02;
import org.apache.struts.action.ActionForm;
//这是ActionForm为了容纳表单的值
//规范:
//1-必须继承org.apache.struts.action.ActionForm
//2-必须编写和表单元素重名的元素属性
//3-必须在Struts配置文件中注册
@SuppressWarnings("serial")
public class QueryForm extends ActionForm{
public QueryForm(){
System.out.println("QueryForm.java构造函数运行");
}
private String sname;
public String getSname() {
System.out.println("QueryForm.java中getSname函数运行");
return sname;
}
public void setSname(String sname) {
this.sname = sname;
System.out.println("QueryForm.java中setSname函数运行");
}
}
queryAction.java文件:
package project02;
import java.util.ArrayList;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import com.dao.StudentDao;
//QueryAction负责接收ActionForm的数据,然后进行处理
//规则:
//1-必须继承org.apache.struts.action.Action
//2-重写excute方法业务逻辑
//3-将这个类在配置文件中注册
public class QueryAction extends Action{
public QueryAction(){
System.out.println("QueryAction.java构造函数运行");
}
@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
QueryForm queryForm=(QueryForm)form;
String sname=queryForm.getSname();
sname=new String(sname.getBytes("iso-8859-1"),"gb2312");
StudentDao studentDao=new StudentDao();
ArrayList stus=studentDao.queryStuByName(sname);
request.setAttribute("stus", stus);
System.out.println("QueryAction.java中execute函数运行");
// 跳转
ActionForward af=new ActionForward("/result.jsp");
//设置了配置文件可以用以下方式跳转
// ActionForward af = mapping.findForward("RESULT");
//以上方式出现异常警告:警告: Unable to find 'RESULT' forward.
return af;
}
}
编写了以上的文件还未能实现struts的功能,要对各个文件之间的关系在struts-config.xml文件进行配置。
struts-config.xml配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN"
"http://struts.apache.org/dtds/struts-config_1_2.dtd">
<struts-config>
<data-sources />
<!-- 在此注册ActionForm -->
<form-beans>
<!-- name:名称 type:类的路径 -->
<form-bean name="queryForm" type="project02.QueryForm"></form-bean>
</form-beans>
<global-exceptions />
<!-- 设置URL的逻辑名称 全局性的,所以的Action都可以识别到-->
<global-forwards>
<forward name="RESULT" path="/result.jsp"></forward>
</global-forwards>
<!-- 这里注册Action -->
<action-mappings>
<!-- name:Actionform的名称 type:类的路径 path:客户端提交给服务器临时指定的路径 -->
<action name="queryForm" path="/query" type="project02.QueryAction"></action>
</action-mappings>
<message-resources parameter="project02.ApplicationResources" />
</struts-config>
最后,对工程文件进行发布,启动tomcat,用浏览器测试。
现在,来梳理清楚。根据需求建立功能。根据要求建立form和action文件。最后对struts-config.xml文件进行配置。
测试操作步骤:
1-进入index.jsp导航页面,点击学生学籍查询进入了queryform.jsp页面
2-进入了queryform.jsp页面,在文本框输入学生名中的一个或两个字进行模糊查询。点击模糊查询。
<form action="/Project02/query.do" method="post">
请您输入学生姓名:<input name="sname">
<input type="submit" value="模糊查询">
</form>
Action:指定了action要执行的路径 method:提交的方式--post不显示信息,get显示信息
3-进入了/Project02/query.do
<!-- 在此注册ActionForm -->
<form-beans>
<!-- name:名称 type:类的路径 -->
<form-bean name="queryForm" type="project02.QueryForm"></form-bean>
</form-beans>
<!-- 这里注册Action -->
<action-mappings>
<!-- name:Actionform的名称 type:类的路径 path:客户端提交给服务器临时指定的路径 -->
<action name="queryForm" path="/query" type="project02.QueryAction"></action>
</action-mappings>
因为配置文件已经完成了配置。注册Action中的path=”/query”就是query.do只是没有了.do后缀。这里已经指定了type类的路径为:project02.QueryAction
4-接下来的就是java文件了,大都能看懂。