Struts:
Struts 是一个java编程的框架,它是基于MVC模式为基础的。它灵活地运用jsp和servlet技术。它是一个插件,是别人已经事先编写好的。我们只使用它的框架来设计编程,这很好的解决了不同人有不同编程习惯的问题。
Struts编程框架:
1-在myeclipse软件中建立一个web project工程文件。名字随意
2-建立完web project后,点击工程文件夹(选中)。再在myeclipse软件中导入struts编程所需要的库文件。步骤:myeclipse软件的myeclipse菜单->project capabilites -> Add capabilites出现
Struts config path:/WEB-INF/struts-config.xml 这是配置文件的路径,默认就好不需要改
Struts specification -----struts的版本。这里选中1.2最新是2.1版
ActionServlet name: action 意思明显,不解析了
URL pattern : 默认是*.do就是执行action的URL路径
Base package for new classes: 这里是包名,可自取名字
Default application resources 不需要修改;
点击Finish完成struts库文件的导入。
导入成功后的文件结构如下:
struts-config.xml:配置文件,在这里新建action,form,jsp
validator-rules.xml:validator 框架的配置文件,该文件别人已经配置好。我们只需要用就行。
其余以struts开始的都是struts标签的配置文件。我们只需要使用即可,当然也可以自我进行配置自己特定的标签。
一个实例演示struts:学生学籍查询(模糊查询)
需求分析:查询学生学籍,要涉及到数据库的操作,要涉及到页面的表单操作。
输入学生名字,点击模糊查询。会返回查询结果。
这里目的只是显示struts的知识点。页面操作等详细细节不做过多要求。
在以上的基础上,在temp包下新建QueryForm.java和QueryAction.java在src下新建两个包,一个是bean文件的,一个操作数据库的,分别是com.bean和com.dao。com.bean下新建StudentBean.java文件com.dao下新建StudentDao.java文件
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文件:
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
-//W3C//DTD HTML 4.01 Transitional//EN">
">
My JSP 'index.jsp' starting pageThis is my JSP page.
学生学籍查询
queryform.jsp文件:
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
-//W3C//DTD HTML 4.01 Transitional//EN">
">
My JSP 'queryform.jsp' starting page查询表单
请您输入学生姓名:
result.jsp文件:
String path = request.getContextPath();
String basePath = request.getScheme() +"://"
+ request.getServerName() +":"+ request.getServerPort()
+ path +"/";
%>
-//W3C//DTD HTML 4.01 Transitional//EN">
">
My JSP 'queryform.jsp' starting page返回结果页面
学号 | 姓名 | 性别 | 出生年月 | 家庭住址 |
for(inti=0;i
StudentBean stu=(StudentBean)stus.get(i);
%>
QueryForm.jsp文件:
packageproject02;
importorg.apache.struts.action.ActionForm;
//这是ActionForm为了容纳表单的值
//规范:
//1-必须继承org.apache.struts.action.ActionForm
//2-必须编写和表单元素重名的元素属性
//3-必须在Struts配置文件中注册
@SuppressWarnings("serial")
publicclassQueryFormextendsActionForm{
publicQueryForm(){
System.out.println("QueryForm.java构造函数运行");
}
privateStringsname;
publicStringgetSname() {
System.out.println("QueryForm.java中getSname函数运行");
returnsname;
}
publicvoidsetSname(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文件进行配置。
配置如下:
-//Apache Software Foundation//DTD Struts Configuration 1.2//EN""http://struts.apache.org/dtds/struts-config_1_2.dtd">
最后,对工程文件进行发布,启动tomcat,用浏览器测试。
现在,来梳理清楚。根据需求建立功能。根据要求建立form和action文件。最后对struts-config.xml文件进行配置。
测试操作步骤:
1-进入index.jsp导航页面,点击学生学籍查询进入了queryform.jsp页面
2-进入了queryform.jsp页面,在文本框输入学生名中的一个或两个字进行模糊查询。点击模糊查询。
请您输入学生姓名:
Action:指定了action要执行的路径method:提交的方式--post不显示信息,get显示信息
3-进入了/Project02/query.do到了QueryAction.java执行。这里为什么是到QueryAction.java文件下执行的呢?
因为配置文件已经完成了配置。注册Action中的path=”/query”就是query.do只是没有了.do后缀。这里已经指定了type类的路径为:project02.QueryAction所以执行QueryAction.java文件。
4-接下来的就是java文件了,大都能看懂。