Java struts 框架编程(Struts1)

来源:互联网 发布:杨辉三角形c语言十行 编辑:程序博客网 时间:2024/05/19 03:16

 原文链接:http://blog.sina.com.cn/s/blog_75f397940101if83.html

Java struts 框架编程

Struts 是一个java编程的框架,它是基于MVC模式为基础的。它灵活地运用jspservlet技术。它是一个插件,是别人已经事先编写好的。我们只使用它的框架来设计编程,这很好的解决了不同人有不同编程习惯的问题。

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 就是执行actionURL路径

Base package for new classes: 这里是包名,可自取名字

Default application resources 不需要修改;

点击Finish完成struts库文件的导入。

 

导入成功后的文件结构如下:

java <wbr>struts <wbr>框架编程

 

struts-config.xml:配置文件,在这里新建actionformjsp

 

validator-rules.xml:validator 框架的配置文件,该文件别人已经配置好。我们只需要用就行。

其余以struts开始的都是struts标签的配置文件。我们只需要使用即可,当然也可以自我进行配置自己特定的标签。


一个实例演示struts:学生学籍查询(模糊查询)

需求分析:查询学生学籍,要涉及到数据库的操作,要涉及到页面的表单操作。

输入学生名字,点击模糊查询。会返回查询结果。

这里目的只是显示struts的知识点。页面操作等详细细节不做过多要求。

在以上的基础上,

1. 在temp包下新建QueryForm.javaQueryAction.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构造函数运行");}  @Overridepublic 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,用浏览器测试。

 

 

现在,来梳理清楚。根据需求建立功能。根据要求建立formaction文件。最后对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  到了QueryAction.java执行。这里为什么是到QueryAction.java文件下执行的呢?

  <!-- 在此注册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 所以执行QueryAction.java文件。

4-接下来的就是java文件了,大都能看懂。












0 0