一、Struts2.0的概述
Struts1的工作原理:
jsp à web.xml(*.do) à ActionServlet(struts-config.xml) à ActionForm(接收参数,validate验证) à 成功(Action) à 失败(input错误页) à jsp
Struts2.0是在WebWork框架基础上开发出来的,结合了一些Struts1框架的优点。
Struts2.0与Struts1的区别:
没有了ActionForm
jsp à web.xml à FilterDispatcher à Action(接收参数,验证,并处理) à 成功(jsp成功页) à 失败(返回input错误页)
可以从Struts官方网站上下载struts2.0的开发包,开发包中包含以下内容:
apps:范例项目
docs:Struts2.0的文档
lib:Struts2.0的支持包
src:Struts2.0的源代码
二、Struts2.0的支持加入
| Struts1.2 | Struts2.0 |
jar包 | struts.jar,commons支持包 | struts2-core.jar,其他支持包 |
核心的配置文件 | WEB-INF/struts-config.xml | WEB-INF/classes/struts.xml |
tld标签库 | WEB-INF/struts-bean.tld等 | 不需要单独加入,在核心jar包中已经保存了 |
资源文件 | 自定义的包下(保存错误信息,完成国际化) | 可以建立多个,自己任意命名。 但其中必须包含一个struts.properties(完成struts2.0的一些默认配置,比如:编码过滤,文件上传大小限制,结合spring等) |
web.xml | 配置ActionServlet | 配置FilterDispatcher过滤器 |
范例:
1、建立项目
2、加入Struts2.0的支持
(1)加入jar包
必须的基本jar包
(2)加入核心配置文件
将范例项目中的一个struts.xml拷贝到项目的src下,删除其他内容,保留框架。
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts> <!--<include file="example.xml"/> -->
<!-- Add packages here --> </struts> |
在“"http://struts.apache.org/dtds/struts-2.0.dtd">”处会有警告信息,并且在编写配置信息时没有了提示;
原因是在在外网“http://struts.apache.org/dtds/”中找,此处可以暂时先改成本地;
在struts2.0的核心jar包中找到struts-2.0.dtd文件,将该文件放到本地的某个文件夹下,此处我放到D:\struts2.0\下
修改核心配置文件:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "D:\struts2.0\struts-2.0.dtd">
<struts> <!--<include file="example.xml"/> -->
<!-- Add packages here --> </struts> |
(3)建立资源文件
手工在src下建立一个struts.properties资源文件
(4)加入标签库?
不需要单独加入,在核心jar包中已经保存了
在页面上如果需要使用标签,需要加入导入标签库的语句、
<%@ taglib uri="/struts-tags" prefix="s" %> |
(5)在web.xml中配置过滤器
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<filter> <filter-name>struts2</filter-name> <filter-class> org.apache.struts2.dispatcher.FilterDispatcher </filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
<welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app> |
这里虽然配置的路径为/*,但默认提交到Action的路径为 *.action
(可以写*.action,但如果写*.action,UI标签就不能使用了?)
3、编写登陆页面
此处修改index.jsp为登陆页
注意:要使用struts2.0标签,需要导入标签
<%@ page language="java" pageEncoding="GBK"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>登陆页</title> </head>
<body> <center> <s:form action="login.action" method="post"> <s:textfield name="userid" label="用户名"></s:textfield> <s:password name="password" label="密码"></s:password> <s:submit value="提交"></s:submit> <s:reset value="重置"></s:reset> <s:fielderror></s:fielderror> </s:form> </center> </body> </html> |
此处通过s:标签完成登陆的表单
4、建立Action
手动建立,即MyEclipse没有提供建立Struts2.0的Action的操作
建立一个Class,继承com.opensymphony.xwork2.ActionSupport类
(Struts2.0承担了Struts1.2的ActionForm和Action的综合功能)
(1)定义属性
a.用来接收参数:定义其setter方法
b.用来回填及向页面传递属性:定义其getter方法
(2)覆写validate方法
(3)覆写execute方法
package mldn.lin.struts.action;
import com.opensymphony.xwork2.ActionSupport;
public class LoginAction extends ActionSupport {
private String userid;
private String password;
//生成setter方法,使Struts2.0可以通过setter对属性进行赋值 public void setPassword(String password) { this.password = password; }
public void setUserid(String userid) { this.userid = userid; }
//生成getter方法,实现回填即向页面传递属性(request范围) public String getPassword() { return password; }
public String getUserid() { return userid; }
//覆写validate方法,实现表单验证 public void validate() { if(userid==null || userid.trim().equals("")){ this.addFieldError("userid", "用户名不能为空!");//userid与页面上文本框的name相同,这样可以自动提示错误信息 } if(password==null || password.trim().equals("")){ this.addFieldError("password", "密码不能为空!"); } }
//覆写execute方法,自动执行 public String execute() throws Exception { // TODO Auto-generated method stub if(userid.equals("mldn") && password.equals("123")){ return "suc"; }else{ this.addFieldError("loginFail", "用户名或密码错误!"); // return "input";//方法1 return ActionSupport.INPUT;//方法2 } }
}
|
5、配置Action
在struts.xml中加入Action的配置
在struts.xml中action的配置都包含在package中,package用来区分不同的Action所映射文件夹路径,这样可以很容易的找到映射的不同路径的Action
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "D:\struts2.0\struts-2.0.dtd">
<struts> <!--<include file="example.xml"/> -->
<!-- Add packages here --> <package name="root" namespace="/" extends="struts-default"> <action name="login" class="mldn.lin.struts.action.LoginAction"> <result name="input">/index.jsp</result> <result name="suc">/suc.jsp</result> </action> </package> </struts> |
6、编写成功页
<%@ page language="java" pageEncoding="GBK"%> <%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>登陆成功页</title> </head>
<body> <center> 欢迎${userid }登陆成功! </center> </body> </html> |
7、部署测试
Struts2.0的UI标签无法使用(或者说很不好用),原因是由于无法控制显示格式和样式
显示错误信息通过 s:fielderror 进行显示,错误信息会自动换行并加入 “.”标志
Action中通过属性的setter方法接收参数并赋值,再调用validate方法进行数据验证,验证完成后,如果添加了错误信息,则返回input错误页,如果通过,则自动调用execute方法,进行业务逻辑处理后,通过return返回不同的页面,如果要向页面传递属性(Attribute),可以使用属性的getter方法进行传递,保存的范围为request范围。
三、Struts2.0新特性
1、处理乱码
输入中文,发现参数接收出现乱码
(1)Struts1.2处理乱码
编码过滤器
package com.mldn.ibm.filter;
import java.io.IOException;
import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse;
public class EncodingFilter implements Filter { private String charSet; public void destroy() { // TODO Auto-generated method stub } public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException { // TODO Auto-generated method stub arg0.setCharacterEncoding(charSet); arg2.doFilter(arg0, arg1); } public void init(FilterConfig arg0) throws ServletException { // TODO Auto-generated method stub this.charSet = arg0.getInitParameter("charset"); } } |
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> <filter> <filter-name>encoding</filter-name> <filter-class>com.mldn.ibm.filter.EncodingFilter</filter-class> <init-param> <param-name>charset</param-name> <param-value>GBK</param-value> </init-param> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app> |
(2)Struts2.0处理乱码
只能通过资源文件的配置来处理
在struts.properties资源文件配置
struts.i18n.encoding=GBK |
i18n表示i到n中间18个字母的一个单词,意思为国际化
2、通过资源文件配置错误提示信息
(1)Struts1.2配置错误提示信息
在Struts的 资源文件中配置
而在ActionForm及Action中
public ActionErrors validate(ActionMapping mapping, HttpServletRequest request) { // TODO Auto-generated method stub ActionErrors errors=new ActionErrors(); if("login".equals(status)){ if(memberid==null || memberid.trim().equals("")){ errors.add("loginMemberidEmpty",new ActionMessage("loginMemberidEmpty.err")); } if(password==null || password.trim().equals("")){ errors.add("loginPasswordEmpty",new ActionMessage("loginPasswordEmpty.err")); }else{ password= new MD5Code().getMD5ofStr(this.password); } } return errors; } |
//Action中 ActionMessages errors=new ActionMessages(); errors.add("loginFail",new ActionMessage("loginFail.err")); this.addErrors(request, errors);
|
//资源文件中 loginMemberidEmpty.err=*\u7528\u6237\u540d\u4e0d\u80fd\u4e3a\u7a7a! loginPasswordEmpty.err=*\u5bc6\u7801\u4e0d\u80fd\u4e3a\u7a7a! loginFail.err=*\u7528\u6237\u540d\u6216\u5bc6\u7801\u9519\u8bef! |
//页面中,如果不加property则显示所有所有发生的错误 <span id="errMessage"><font size="-1" color="red"><html:errors property="loginMemberidEmpty" />< |