Struts2框架基础篇

    xiaoxiao2023-08-12  162

    首先,要了解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还提供了很多内置的校验器,可以直接使用:

    1. required校验器 此校验器要求字段必须为非空;   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>

    相关资源:敏捷开发V1.0.pptx
    最新回复(0)