Struts2 请求参数验证
来源:互联网 发布:极点五笔for mac版 编辑:程序博客网 时间:2024/05/29 18:37
请求参数验证
两种方式:
手动校验
配置校验(xml)
1. 手动校验(了解)
继承ActionSupport,重写validate()方法,在该方法中完成验证,validate()方法在其他的业务方法之前执行
验证出错后转向的页面 struts.xml配置<result name="input">/validate/login.jsp</result>
什么时候表示验证出错?
this.addFieldError(“a”,”错误信息”);方法指向的一个集合
当集合不为空时,转向错误页面。
在jsp页面中使用 <s:fielderror> 展示所有错误信息
<s:fielderror fieldName="">展示特定名称的错误信息
2. 配置校验(重点)
要求:action类必须继承自ActionSupport
配置文件:
位置:xml文件要与action类在同一个包下
名称:action类名-validation.xml 约束: xwork-core-2.3.7.jar 中 xwork-validator-1.0.3.dtd 下
<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.3//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">
写法:
1)根元素
2)子元素,name为页面被验证的表单字段的名称
3)的子元素 这个是指定校验器
校验器有哪些?
在xwork-core-2.3.7.jar 中 /com/opensymphony/xwork2/validator/validators/default.xml下 <validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator"/> <validator name="requiredstring" class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator"/> <validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator"/> <validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator"/> <validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator"/> <validator name="double" class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/> <validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/> <validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator"/> <validator name="fieldexpression" class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator"/> <validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator"/> <validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator"/> <validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator"/> <validator name="conversion" class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator"/> <validator name="stringlength" class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator"/> <validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator"/> <validator name="conditionalvisitor" class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator"/>
4)的子元素错误信息
5)子元素的值用于指定校验器中的参数`
系统提供的校验器:
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指定最大值)
required 必填校验器
<field-validator type="required"><message>性别不能为空!</message></field-validator>requiredstring 必填字符串校验器<field-validator type="requiredstring"> <param name="trim">true</param> <message>用户名不能为空!</message></field-validator>stringlength:字符串长度校验器<field-validator type="stringlength"> <param name="maxLength">10</param> <param name="minLength">2</param> <param name="trim">true</param> <message><![CDATA[产品名称应在2-10个字符之间]]></message></field-validator>int:整数校验器<field-validator type="int"> <param name="min">1</param> <param name="max">150</param> <message>年龄必须在1-150之间</message></field-validator>date: 日期校验器<field-validator type="date"> <param name="min">1900-01-01</param> <param name="max">2050-02-21</param> <message>生日必须在${min}到${max}之间</message></field-validator>url: 网络路径校验器<field-validator type="url"> <message>传智播客的主页地址必须是一个有效网址</message></field-validator>email:邮件地址校验器<field-validator type="email"> <message>电子邮件地址无效</message></field-validator>regex:正则表达式校验器<field-validator type="regex"> <param name="regexExpression"><![CDATA[^13\d{9}$]]></param> <message>手机号格式不正确!</message></field-validator>fieldexpression : 字段表达式校验<field-validator type="fieldexpression"> <param name="expression"><![CDATA[(password==repassword)]]></param> <message>两次密码输入不一致</message></field-validator>对action中的指定方法进行校验当校验文件的取名为ActionClassName-validation.xml时,会对action中的所有处理方法实施输入验证,如果只需要对action中的某个action方法校验,那么,校验文件的取名应该为ActionClassName-ActionName-validation.xml,其中ActionName为Struts.xml中action的名称。例如:<action name="user_*" class="com.java.action.UserAction" method="{1}" > <result name="success">/WEB-INF/page/message.jsp</result> <result name="input">/WEB-INF/page/addUser.jsp</result></action>
在UserAction中有两个处理方法:
public String add() throws Exception{}
public String update() throws Exception{}
要对add()方法实施验证,校验文件取名为:UserAction-user_add-validation.xml
要对update()方法实施验证,校验文件取名为:UserAction-user_update-validation.xml
- Struts2 请求参数验证
- Struts2接受请求参数
- struts2 请求参数接收
- Struts2接收请求参数
- Struts2 请求参数接收
- struts2请求参数处理
- Struts2 封装请求参数
- Struts2---请求参数校验
- struts2-请求参数校验
- Struts2学习之2(请求参数的封装,类型转换,输入验证,自定义拦截器)
- Struts2 请求参数的接收
- Struts2接收请求参数原理
- struts2请求参数的接收
- Struts2(三) 接受请求参数
- Struts2如何封装请求参数
- Struts2如何封装请求参数
- Struts2中获取请求参数
- Struts2中请求参数校验
- npm镜像切换大法
- Linux基础练习一
- 神经网络中的激活函数-Sigmoid, ReLu, TanHyperbolic(tanh), softmax, softplus简述
- 连咸鱼都能学会的Java异步处理
- Android Binder设计与实现
- Struts2 请求参数验证
- 最后一波9.9元电子书秒杀,你真的不来看一看吗?
- runtime从入门到精通(三)—— runtime常用接口方法
- Python 元组
- 机器学习(6)-神经网络
- java 静态内部类不可以继承非静态内部类理解
- googLenet
- QEMU模拟Mini2440开发板运行环境
- linux下的"BusHound"——usb_mon