java struts 框架_java struts 框架编程

Struts:

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

Struts编程框架:

1-在myeclipse软件中建立一个web project工程文件。名字随意

2-建立完web project后,点击工程文件夹(选中)。再在myeclipse软件中导入struts编程所需要的库文件。步骤:myeclipse软件的myeclipse菜单->project capabilites -> Add capabilites出现

a4c26d1e5885305701be709a3d33442f.png

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库文件的导入。

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

a4c26d1e5885305701be709a3d33442f.png

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 page

This 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文件了,大都能看懂。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值