首先,要了解Struts2框架中参数传递的大体流程:
服务器端的Web容器收到用户的请求(URL)——Struts2的核心控制器FilterDispatcher接受用户发起的请求,然后判断这个请求是交给action还是交给web组件来处理;如果请求的action或web组件不存在,就会报错404。在整个处理过程中,需要一个辅助对象: ActionMapper ,它会确定调用哪个Action——相应的action会根据struts.xml的配置信息(首先执行拦截此action的所有拦截器,然后再执行请求的action对象;在这个处理过程中需要辅助对象:Action代理类ActionProxy)配置管理器(ConfigurationManager)——Action执行完毕之后,返回一个结果(此结果用字符串来表示),这个结果经过拦截Action的所有拦截器之后,返回给主控制器。主控制器根据此结果从配置文件中找到真正的路径,然后将请求转发给相应的视图。视图根据持久层作出相应的反应。整个参数传递的流程就结束了。
其次,导入Struts所需的jar文件。
Struts2要使用一些jar包文件,开发业务需求不一样,所需的包配置也不一样,以下这些包是最基本的,(一般情况下这些包也够用了),所需包的放置位置是\WebRoot\WEB-INF\lib:
其中
struts-core-2.jar 是Struts 2 框架的核心类库
xwork-core.jar 是XWork类库,Struts 2 在其上构建
ognl.jar 是 Object Graph Navigation Language , Struts 2 框架通过其读写对象的属性。
freemarker.jar 是Struts 2 的UI标签的模版使用 Freemarker编写。
commons-logging.jar 是ASF出品的日志包。
commons-fileupload.jar 是文件上传组件。
导包完成后要创建Struts.xml,这是Struts 2 的核心配置文件,主要用于配置开发人员编写的action。
该配置文件通常放在src下,下面通过一个Struts.xml文件,详细分析一下这个核心配置文件:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <!-- package:包.structs2使用package来组织 name 属性:用于其他的包应用当前的包(必填属性) extends:当前包继承哪个包,继承的,即可用继承其中的所有的配置,通常情况下继承struts-default struts-default这个包在struts-default.xml文件中定义 namespace 属性是可选的,如果它没给出,则以“/”为默认值.若namespace有一个默认值,则要想调用这个包里的Action 就必须把这个属性所定义的命名空间添加到有关的UR字符串中 --> <package name="helloworld" extends="struts-default"> <!-- 配置一个action:一个struts2的请求就是一个action name:对应一个struts2的请求的名字,不包含扩展名 class:com.opensymphony.xwork2.ActionSupport method 默认值:execute --> <action name="product-input" class="com.opensymphony.xwork2.ActionSupport" method="execute"> <!-- result:结果.表示action方法执行后可能返回一个结果,所以一个action节点可能会有多个result子节点. 多个result子节点使用name属性区分 name:表示一个result 和action方法的返回值对应 默认值为success type:表示结果类型,默认值为dispatcher(转发到结果) --> <result name="success" type="dispatcher">/WEB-INF/pages/xxx.jsp</result> </action> <!-- class = "xxxx" 对应请求的包名加类名 --> <action name="product-save" class="xxxx" method="save"> <result name="detais">/WEB-INF/pages/xxxx.jsp</result> </action> </package> </struts>
在Struts 2中,Struts框架是通过Filter启动,在web.xml中必须有相应的配置:
<filter> <filter-name>struts2</filter-name> <filter-class> org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter </filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
struts 2 在读取到 struts.xml的内容后,以javabean形式存放在内存中,以后Struts 2对每一次请求处理将使用内存中的数据。
Struts2提供了大量的数据校验器,有两种方法进行数据的校验:
1, 编码方式校验:
Action继承自ActionSupport,针对某个要进行校验的请求处理方法编写一个 public void validateXxx()方法,在方法内部进行表单数据校验.这种方法不提倡,和主代码容易造成代码混乱而且不易重用,需要为每个需要的地方加校验。
2,XML配置的方法校验:
针对要校验的Action类,在同包下编写一个名为:Action类名-validation.xml校验规则文件,这种是比较常用的,
命名规则:ActionName-validation.xml,其中ActionName是Action类的名字;
输入校验失败后,和类型转换一样,会将错误封装成fieldError,并放入Action Context中,因此在JSP中添加<s:fielderror/>可显示错误,此内容也是我们在数据校验文件中配置的;
例如:必填校验器
对登录用户名进行非空验证:
<validators> <!-- 需要验证的字段的字段名 --> <field name = "username"> <field-validators type = "required"> <!-- 错误提示信息 --> <message>请输入用户名</message> </field-validators> </field> </validators>
年龄合法性验证:
<validator type="int"> <param name="fieldName">age</param> <param name="min">0</param> <param name="max">150</param> <message>年龄范围在0-150之间</message> </validator>
日期验证(包括输入的是否 是date类型以及输入的日期是否合法)
<validators> <!-- 需要验证的字段的字段名 --> <field name = "date"> <field-validators type = "date"> <!-- 时间的最小值 --> <param name = "min">2000-01-01</param> <!-- 时间的最大值 --> <param name = "max">2017-05-04</param> <!-- 错误提示信息 --> <message>时间必须在2000-01-01至2017-05-04之间</message> </field-validators> </field> </validators>
同时,struts2还提供了很多内置的校验器,可以直接使用:
此校验器要求字段必须为非空;
2 .requiredstring校验器
此校验器要求检验字符串非空并且必须长度大于0,即不能是""
可选参数为:
(1)trim:如果为true,则将前后的空白去掉,类似于String的trim函数;
3. int校验器
此校验器要求整数限定在一定范围之内;
可选参数为:
(1)min:最小值;
(2)max:最大值;
4. date校验器
要求日期在一定范围之内;
可选参数:
(1)min:最小日期;
(2)max:最大日期;
5. fieldexpression校验器
要求此校验器满足指定的逻辑表达式;
可选参数:
(1)expression:逻辑表达式;格式为:<![CDATA[(逻辑表达式)]]>
6. email校验器
要求字段一定要满足电子邮箱格式;
7. url校验器
要求字段格式满足URL格式;
8. stringlength校验器
要求字段是string,并且长度在一定范围之内;
可选参数:
(1)trim:删除前后空白;
(2)minLength:最小长度;
(3)maxLength:最大长度;
9. regex校验器
要求满足给定的正则表达式;
可选参数:
(1)expression:给出正则表达式;格式如:<![CDATA[(正则表达式)]]>
(2)caseSensitive:是否区分大小写;
例如,当我们要验证邮箱时,不需要自己做验证,
<validators> <!-- 需要验证的字段的字段名 --> <field name = "email"> <field-validators type = "email"> <!-- 错误提示信息 --> <message>邮箱地址无效</message> </field-validators> </field> </validators>