一、Action处理请求参数

  • 在Struts2中获取请求参数:有两类方式(三种方法)

1.1 属性驱动

  1. 直接将action做一个model,就可以得到请求参数.

    • 问题1:action封装请求参数,会不会存在线程安全问题?
    • 不会:因为每一次请求,都是一个新的action。
    • 缺点:会有重复代码,需要单独定义javaBean,将action中属性copy到javaBean中。
    • 优点:简单。
    • 这种方式 ,底层是通过反射来实现的。
  2. 在action中声明一个model。

    • private User user;提供get/set方法
    • 在页面上使用ognl来描述
    1. <input type="text" name="user.username">
    • 优点:简单,解决了第一种封装的问题
    • 缺点:在页面上使用了ognl表达式,页面不通用了。实际开发中的页面 都要通用,换了另一种框架保证页面还可以正常显示。
    • 问题:这种方式,数据是怎样封装的?
    • 是通过struts2中的interceptor进行了数据封装.
    • 在struts-default.xml 中有默认的拦截器
    1. <interceptor name="params" class="com.opensymphony.xwork2.interceptor.ParametersInterceptor"/>

1.2 模型驱动

  • 此种方式在开发中应用的比较多
  • 步骤:
    • 1.让action类实现ModelDriven
    • 2.重写getModel方法
    • 3.在action中实现化一个model对象,让getModel方法返回这个对象。
  • 代码如下:
  1. //获取请求参数 模型驱动
  2. public class Login3Action extends ActionSupport implements ModelDriven<User> {
  3. private User user = new User();
  4. public User getModel() {
  5. return user;
  6. }
  7. @Override
  8. public String execute() throws Exception {
  9. HttpServletRequest request = ServletActionContext.getRequest();
  10. // 2.判断用户名与密码是否正确
  11. if ("tom".equals(user.getUsername())
  12. && "123".equals(user.getPassword())) {
  13. request.getSession().setAttribute("username", user.getUsername());
  14. return SUCCESS;
  15. } else {
  16. request.setAttribute("login.message", "用户名或密码错误");
  17. return "failer";
  18. }
  19. }
  20. }
  • 优点:解决了属性驱动存在的问题
  • 缺点:一次只能封装一个model对象.
  • struts2 有很多围绕模型驱动的特性
  1. <interceptor name="modelDriven" class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>

1.3 扩展

将数据封装到List集合

  • JSP页面:
  1. username1:<input type="text" name="users[0].username"><br>
  2. password1:<input type="password" name="users[0].password"><br>
  3. username2:<input type="text" name="users[1].username"><br>
  4. password2:<input type="password" name="users[1].password"><br>
  • Action类:
  1. private List<User> users;
  2. public List<User> getUsers() {
  3. return users;
  4. }
  5. public void setUsers(List<User> users) {
  6. this.users = users;
  7. }

将数据封装到Map集合

  • JSP页面:
  1. username1:<input type="text" name="map['aaa'].username"><br>
  2. password1:<input type="password" name="map['aaa'].password"><br>
  3. username2:<input type="text" name="map['bbb'].username"><br>
  4. password2:<input type="password" name="map['bbb'].password"><br>
  • Action类:
  1. private Map<String, User> map;
  2. public Map<String, User> getMap() {
  3. return map;
  4. }
  5. public void setMap(Map<String, User> map) {
  6. this.map = map;
  7. }

二、类型转换

  • 在属性驱动和模型驱动的实现中利用到了beanutils 直接将表单数据封装到了javaBean中,其中beanutils中自己提供了一部分的类型转换
  • 在web中我们使用beanutils直接将表单数据封装到javaBean中。---类型转换
  • struts2中action得到请求参数,也可以直接封装到javaBean.
  • struts2 内部提供大量类型转换器,用来完成数据类型转换问题
  • boolean 和 Boolean
  • char和 Character
  • int 和 Integer
  • long 和 Long
  • float 和 Float
  • double 和 Double
  • Date 可以接收 yyyy-MM-dd格式字符串
  • 数组 可以将多个同名参数,转换到数组中
  • 集合 支持将数据保存到 List 或者 Map 集合
  • 例如:日期类型,我们传递 yyyy-MM-dd yyyy年MM月dd日格式都可以,但是如果是yyyy/MM/dd ,就会出现问题.

  • struts2中的类型转换器根接口是:com.opensymphony.xwork2.conversion.TypeConverter

2.1 自定义类型转换器:

  • 步骤:
  • 1.创建一个类实现TypeConverter接口.
  • 2.重写接口中方法,实现类型转换操作.
  • 3.注册类型转换器.

  • 详解说明:

1.创建一个自定义类型转换器

  • 有下面的几种方式
  • 实现TypeConverter需要重写
  1. public Object convertValue(Map<String, Object> context, Object target, Member member, String propertyName, Object value, Class toType);
  2. // 如果实现接口,这个方法参数太多(6个)
  • 不推荐实现接口,可以继承 DefaultTypeConverter类,优点:重写的方法参数没有那么多,需要重写下面的方法
  1. public Object convertValue(Map<String, Object> context, Object value, Class toType) {
  2. return convertValue(value, toType);
  3. }
  • 推荐使用 ,继承DefaultTypeConverter类的一个子类StrutsTypeConverter.
    原因:在这个类中将从页面传递的数据怎样封装,以及action中的数据怎样在页面上显示做了分离.需要重写下面的两个方法:
  1. public abstract Object convertFromString(Map context, String[] values, Class toClass);
  2. public abstract String convertToString(Map context, Object o);

2.注册一个自定义类型转换器.

  • 1.局部--针对于Action (这种方式好像是需要属性驱动的)

    • 配置文件所在位置以及名称: 在Action类所在包 创建 Action类名-conversion.properties
    • 配置文件书写格式: 属性名称=类型转换器的全类名
  • 2.局部--针对于Model
    • 配置文件所在位置以及名称: 在Model类所在包 创建 model类名-conversion.properties
    • 配置文件书写格式: 属性名称=类型转换器的全类名
  • 3.全局

    • 配置文件所在位置以及名称:在src下创建一个xwork-conversion.properties
    • 配置文件书写格式: 要转换的类型全名=类型转换器的全类名
  • 注意:

  • 对于struts2中类型转换器,如果表单数据提交时,将数据向model封装,出现了问题,会报错: No result defined for action com.hao.action.RegistAction and result input

  • 上面的意思是说,在RegistAction的配置中没有配置input结果视图.

  • 要在struts.xml 的action中添加input 视图

  1. <action name="regist" class="cn.itcast.action.RegistAction">
  2. <result name="input">/success.jsp</result>
  3. </action>
  • 如果配置了,出现类型转换问题,就会跳转到input指定的视图。
  • 为什么会向input视图跳转呢,这 是因为struts2中的默认的拦截器(interceptor).
    如下:
  1. <interceptor name="conversionError" class="org.apache.struts2.interceptor.StrutsConversionErrorInterceptor"/>
  1. <interceptor name="workflow" class="com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor"/>
  • 用于得到问题,向input视图跳转。 分析见下图:


关于类型转换设置input视图分析
  • 关于错误信息展示:
  • 通过分析拦截器作用,得知当类型转换出错时,自动跳转input视图 ,在input视图页面中 <s:fieldError/> 显示错误信息
  • 在Action所在包中,创建 ActionName.properties,在局部资源文件中配置提示信息: invalid.fieldvalue.属性名 = 错误信息
  • 如果是自定义类型转换器,出现类型转换问题,要跳转到input视图,在类型转换器中,必须抛出异常才可以。

三、数据校验

  • 在开发中,请求参数是需要校验的。
  • 客户端校验---->js
  • 服务器校验---->java代码。
  • struts2中提供的校验-----服务器端校验。

  • 分成两种:

  • 1.手动校验(编码校验)

  • 2.配置校验(annotation,xml) 我们讲的是xml。

3.1 手动校验

  • 要求:Action类必须继承自ActionSupport。需要重写一个方法 validate
  • 通过测试发现在Action中重写的validate方法执行了。并且是在请求处理方法(execute)之前执行的。
  • 对于struts2提供的校验,它也是通过拦截器实现的。
  • 问题:在validate方法中怎样存储校验错误信息?
  • 在validate方法中 this.addFieldError(Sting name,String value);
  • 问题:在页面上怎样获取错误信息?(在input视图上)
  • <s:fielderror>展示所有错误信息
    *<s:fielderror fieldName=""> 展示特定名称的错误信息.
  • 问题:在同一个Action中有多个请求处理方法(login,regist)那么有些方法是需要校验的,有些是不需要的,怎样处理?
  • 解决方案:创建一个名称叫 validate+请求处理方法名 例如:请求处理方法叫 regist() 校验的方法名 validateRegist()

3.2 配置校验(xml)

  • struts2的校验框架。
  • 已经完成了校验操作(做了很多校验方法)。
  • 而我们在使用时,只需要将它们调用就可以(通过配置文件)
  • 要求:action类必须继承自ActionSupport
  • 问题:配置文件怎样配置?
  • 位置:xml文件要与action类在同一个包下
  • 名称:action类名-validation.xml

示例如下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE validators PUBLIC
  3. "-//Apache Struts//XWork Validator 1.0.3//EN"
  4. "http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">
  5. <validators>
  6. <!-- 对username属性进行校验 -->
  7. <field name="username">
  8. <!-- 指定username不能为空 -->
  9. <field-validator type="requiredstring">
  10. <!-- 错误信息 -->
  11. <message>用户名不能为空--------</message>
  12. </field-validator>
  13. <!-- 长度校验,规定用户名必须在6-10位之间 -->
  14. <field-validator type="stringlength">
  15. <param name="maxLength">10</param>
  16. <param name="minLength">6</param>
  17. <message>用户名必须在${minLength}-${maxLength}位之间</message>
  18. </field-validator>
  19. </field>
  20. <!-- 对age进行校验,规定年龄必须在10-40之间 -->
  21. <field name="age">
  22. <field-validator type="int">
  23. <param name="min">10</param>
  24. <param name="max">40</param>
  25. <message>年龄必须在${min}--${max}之间</message>
  26. </field-validator>
  27. </field>
  28. <!-- 对birthday进行校验 -->
  29. <field name="birthday">
  30. <field-validator type="date">
  31. <param name="min">1974-01-01</param>
  32. <param name="max">2004-12-31</param>
  33. <message>生日必须在${min}年到${max}年之间</message>
  34. </field-validator>
  35. </field>
  36. <!-- 校验邮箱 -->
  37. <field name="email">
  38. <field-validator type="email">
  39. <message>邮箱格式不正确</message>
  40. </field-validator>
  41. </field>
  42. <!-- url校验 -->
  43. <field name="url">
  44. <field-validator type="url">
  45. <message>url不能这空,类似于http://www.baidu.com</message>
  46. </field-validator>
  47. </field>
  48. <!-- 使用正则 -->
  49. <field name="telphone">
  50. <field-validator type="regex">
  51. <param name="regexExpression"><![CDATA[^135[0-9]{8}$]]></param>
  52. <message>电话号码必须是135xxxxxxxx</message>
  53. </field-validator>
  54. </field>
  55. <field name="repassword">
  56. <field-validator type="fieldexpression">
  57. <param name="expression"><![CDATA[(password==repassword)]]></param>
  58. <message>两次密码输入不一致</message>
  59. </field-validator>
  60. </field>
  61. </validators>
  • 示例分析

  • 1.约束: xwork-core-*.jarxwork-validator.dtd

  1. <!DOCTYPE validators PUBLIC
  2. "-//Apache Struts//XWork Validator //EN"
  3. "http://struts.apache.org/dtds/xwork-validator.dtd">
  • 2.标签
  1. 1.根元素
  2. <validators>
  3. 2.子元素
  4. <field name="属性名称"></field>
  5. 3.<field>子元素
  6. <field-validator type="校验器"> 这个是指定校验器
  • 3.问题:校验器有哪些?
  • xwork-core-*jar/com/opensymphony/xwork2/validator/validators/default.xml
  1. <validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator"/>
  2. <validator name="requiredstring" class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator"/>
  3. <validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator"/>
  4. <validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator"/>
  5. <validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator"/>
  6. <validator name="double" class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/>
  7. <validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/>
  8. <validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator"/>
  9. <validator name="fieldexpression" class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator"/>
  10. <validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator"/>
  11. <validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator"/>
  12. <validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator"/>
  13. <validator name="conversion" class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator"/>
  14. <validator name="stringlength" class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator"/>
  15. <validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator"/>
  16. <validator name="conditionalvisitor" class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator"/>
  • 4.<field-validator>子元素

    • <message>错误信息</message>
  • 5.<field-validator>子元素

    • <param name="">值</param> ,用于指定校验器中的参数.
  • 介绍:关于配置校验中的校验器:

  • required (必填校验器,要求被校验的属性值不能为null)

  • requiredstring (必填字符串校验器,要求被校验的属性值不能为null,并且长度大于0,默认情况下会对字符串去前后空格)

  • stringlength (字符串长度校验器,要求被校验的属性值必须在指定的范围内,否则校验失败,minLength参数指定最小长度,maxLength参数指定最大长度,trim参数指定校验field之前是否去除字符串前后的空格)

  • regex (正则表达式校验器,检查被校验的属性值是否匹配一个正则表达式,expression参数指定正则表达式,caseSensitive参数指定进行正则表达式匹配时,是否区分大小写,默认值为true)

  • int(整数校验器,要求field的整数值必须在指定范围内,min指定最小值,max指定最大值)

  • double(双精度浮点数校验器,要求field的双精度浮点数必须在指定范围内,min指定最小值,max指定最大值)

  • fieldexpression (字段OGNL表达式校验器,要求field满足一个ognl表达式,expression参数指定ognl表达式,该逻辑表达式基于ValueStack进行求值,返回true时校验通过,否则不通过)

  • email(邮件地址校验器,要求如果被校验的属性值非空,则必须是合法的邮件地址)

  • url(网址校验器,要求如果被校验的属性值非空,则必须是合法的url地址)

  • date(日期校验器,要求field的日期值必须在指定范围内,min指定最小值,max指定最大值)

  • 问题:通过配置校验,怎样处理在同一个action中存在多个请求处理方法校验问题?

  • 只需要将校验xml文件名称修改就可以。

  • action类名-valication.xml 现在要对action类中某一个方法校验。

  • action类名-action中要校验的方法名-validation.xml

  • UserAction-login-validation.xml


关于struts2中校验操作分析

【Struts2】进阶的更多相关文章

  1. Struts2进阶(一)运行原理及搭建步骤

    Struts2进阶(一)运行原理 Struts2框架 Struts2框架搭建步骤 致力于web服务,不可避免的涉及到编程实现部分功能.考虑使用到SSH框架中的Struts2.本篇文章只为深入理解Str ...

  2. Struts2进阶学习4

    Struts2进阶学习4 自定义拦截器的使用 核心配置文件 <?xml version="1.0" encoding="UTF-8"?> <! ...

  3. Struts2进阶学习3

    Struts2进阶学习3 OGNL表达式与Struts2的整合 核心配置文件与页面 <?xml version="1.0" encoding="UTF-8" ...

  4. SSH开发模式——Struts2进阶

    在之前我有写过关于struts2框架的博客,好像是写了三篇,但是之前写的内容仅仅是struts2的一些基础知识而已,struts2还有很多有趣的内容等待着我们去发掘.我准备再写几篇关于struts2的 ...

  5. struts2进阶篇(2)

    一.Action与MVCstruts2是一个基于MVC的web应用框架,它将应用程序分为三个组件:模型,视图,控制器.模型:包含了应用程序的业务逻辑和业务数据,由封装数据和处理业务的javaBean组 ...

  6. struts2进阶篇(5)

    一.OGNL简介 OGNL (Object-Graph Navigation Language)的缩写,简称对象图导航语言. OGNL表达式的特特点: >能够取对象的属性,也能调用对象的方法. ...

  7. struts2进阶篇(4)

    一.使用ActionContext访问Servlet API strtus2提供了一个ActionContext类,该类别称为Action上下文或者Action环境,Action可以通过该类来访问最常 ...

  8. struts2进阶

    Struts2 一.Struts的工作原理 Struts2的工作机制3.1Struts2体系结构图 Strut2的体系结构如图15所示: (图15) 3.2Struts2的工作机制 从图15可以看出, ...

  9. struts2 进阶--异常捕获机制

    在SpringMvc中有自己的异常处理机制,struts2当然会有此功能,主要是在struts.xml中配置: <bean type="com.opensymphony.xwork2. ...

  10. J2EE进阶(二)从零开始之Struts2

    J2EE进阶(二)从零开始之Struts2 以前自己总是听说什么SSH框架,不明觉厉.现在自己要重整旗鼓,开始系统性的学习SSH框架了.首先开始Struts2的学习.其实自己之前参与过Struts2项 ...

随机推荐

  1. mvn安装

    先安装jdk.jre,maven需要jdk.jre支持 1.安装 jdk 卸载自带jdk rpm -qa | grep jdk rpm -e --nodeps 下载 JDK JDK 下载地址:http ...

  2. Spring Aop(五)——给Advice传参

    转发:https://www.iteye.com/blog/elim-2395337 5 给Advice传递参数 Advice除了可以接收JoinPoint(非Around Advice)或Proce ...

  3. 嵌入(embedding)层的理解

    首先,我们有一个one-hot编码的概念. 假设,我们中文,一共只有10个字...只是假设啊,那么我们用0-9就可以表示完 比如,这十个字就是“我从哪里来,要到何处去” 其分别对应“0-9”,如下: ...

  4. IDEA配置SpringBoot应用的profile启动参数

    参考博客:https://blog.csdn.net/li396864285/article/details/83576829 如图为, 配置多台eureka的启动参数, 分别为: --spring. ...

  5. Hyperledger Fabric 常用命令

    Peer常用命令: #peer chaincode --help #peer channel list --help --logging-level <string> #<strin ...

  6. 建立自己的数据类型——C结构体归纳

    一.建立结构体类型 1.申明结构体类型 struct 结构体名 { 成员表列(类型名 成员名:); }: 例如: struct Person { char name; int age; char se ...

  7. Qt——鼠标拖动缩放窗口源码

    #ifndef MOVEWIDGET_H #define MOVEWIDGET_H #include <QWidget> #include <QEvent> class Mov ...

  8. STM32PWM之——定时器(1)

    定时器功能简介 STM32 一共有 8 个都为 16 位的定时器.其中 TIM6. TIM7 是基本定时器:TIM2.TIM3. TIM4. TIM5 是通用定时器: TIM1 和 TIM8 是高级定 ...

  9. go 二进制数据处理

    以下是利用标准库binary来进行编解码 编码 ①使用bytes.Buffer来存储编码生成的串②使用binary.Write来编码存储在①的buf中 package main import ( &q ...

  10. JavaScript之二分法

    二分法:   二分查找,又称为折半查找.   注意:二分法查找的数组必须是有序的. /* 获取元素88在数组中第一次出现的索引位置 如果数组元素中存在88,则直接返回88在数组中的索引位置即可. 如果 ...