第一种方式: 重写validation方法,

====验证action中所有的方法:

1. 在UserAction1里重写validation:

 @Override
public void validate() {
// TODO Auto-generated method stub
if(user.getUsername().trim().equals("")||user.getUsername()==null){
this.addFieldError("username_error", "用户名不能为空");
}
if(user.getPassword().length()<4||user.getPassword().length()>6){
this.addFieldError("password_error","密码必须为4~6位");
}
String check = "^([a-z0-9A-Z]+[-|_|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$";
Pattern regex = Pattern.compile(check);
Matcher matcher = regex.matcher(user.getEmail());
if(!matcher.matches()){
this.addFieldError("email_error", "电子邮箱格式不正确");
}
super.validate();
}

  

2. struts文件的设置,需要增加input的result name,写在当前action name下

<result name="input">/login.jsp</result>

  

3. jsp文件里的显示:

//前面加上标签使用库
<%@taglib uri="/struts-tags" prefix="s" %> <s:fielderror cssStyle="color:red"/> //显示错误信息
<form name="loginForm" action="<%=path%>/login.action" method="post">
<br><input type="button" value="登录1" onclick="javascript:document.loginForm.action='<%=path%>/user/login1.action';document.loginForm.submit();"/>
<br><input type="button" value="登录2" onclick="javascript:document.loginForm.action='<%=path%>/user/login2.action';document.loginForm.submit();"/>

<br><input type="button" value="登录3" onclick="javascript:document.loginForm.action='<%=path%>/user/login3.action';document.loginForm.submit();"/>

<br><input type="button" value="登录4" onclick="javascript:document.loginForm.action='<%=path%>/user/login4.action';document.loginForm.submit();"/>
<br>

====部分方法验证:

1. 在UsersAction3.java里加入:

 public void validateAdd(){
if(user.getEmail()==null||user.getEmail().trim().equals("")){
this.addFieldError("email_error","电子邮箱不能为空");
}
}

2.  需要给方法处理所在的action 配置result name:

 <result name="input">/login_success.jsp</result>

3. 在login_success.jsp里显示错误信息:

<s:fielderror cssStyle="color:red"/>

输入用户名和密码, 邮箱为空,验证

====validation方法重写+XML结合验证:

1. 在UsersAction3.java里全部验证

 public void validate(){
if(user.getEmail()==null||user.getEmail().trim().equals("")){
this.addFieldError("email_error","电子邮箱格式不正确");
}
}

  

2. xml配置:

 <interceptor-ref name="defaultStack">
<param name="validation.includeMethods">add,delete</param>
</interceptor-ref>

由于是全部验证, 所以应该是所有add,delete,modify都会验证,但是由于添加了xml的配置, 所以只有add,delete进行验证, modify被过滤掉了,不会进行验证.  

  

第二种方式:XML文档方式: UsersAction.java同包里加入一个文件UsersAction2-validation.xml:

<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.2//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.2.dtd">
<validators>
<field name="username">
<field-validator type="requiredstring">
<message>
用户名不能为空
</message>
</field-validator>
</field> <field name="password">
<field-validator type="requiredstring">
<message>
密码不能为空
</message>
</field-validator>
<field-validator type="stringlength">
<param name="minLength">4</param>
<param name="maxLength">6</param>
<message>密码必须是4~6位</message>
</field-validator>
</field> <field name="email">
<field-validator type="requiredstring">
<message>
邮箱名不能为空
</message>
</field-validator>
<field-validator type="email">
<message>邮箱格式不正确</message>
</field-validator>
</field>
</validators>

 

第三种方式:Annotation注解方式:

在UsersAction3.java里全部验证后, 对单独的方法前面加上:

@SkipValidation

@SkipValidation
public String delete(){
System.out.println("删除");
return SUCCESS;
}

如果从上面延续下来的话,那么add验证, delete不会验证.

@SkipValidation的意思理解就是: 抢到return result的权利用户名不能为空密码不能为空46 密码为4~6位 电子邮箱不能为空 电子邮箱格式不正确 自动还显示当前login.jsp界面: jsp文件里的显示: 第3种方式: :Annotation: action里全部验证格式: public void validate(){ if(user.getEmail()==null||user.getEmail().trim().equals("")){ this.addFieldError("email","电子邮箱不能为空"); } } 但是在add, delete,modify,execute等方法前面写上@SkipValidation 就可以跳过验证 @SkipValidation的意思理解就是: 抢到return result的权利

Struts2 语法--验证方式:的更多相关文章

  1. 【Java EE 学习 35 下】【struts2】【struts2文件上传】【struts2自定义拦截器】【struts2手动验证】

    一.struts2文件上传 1.上传文件的时候要求必须使得表单的enctype属性设置为multipart/form-data,把它的method属性设置为post 2.上传单个文件的时候需要在Act ...

  2. struts2 的验证框架validation如何返回json数据 以方便ajax交互

    struts2 的验证框架validation简单,好用,但是input只能输出到jsp页面通过struts2的标签<s:fielderror  />才能取出,(EL应该也可以). 如果使 ...

  3. Struts2 框架验证

    struts2框架验证(xml方式):    * 首先要从页面中获取对应的标签name属性的值,在动作类action中声明同名的属性,提供get和set方法        * 创建一个xml格式验证文 ...

  4. Struts2数据验证机制

    1. 手动验证的实现 只需要在继承ActionSupport类的情况下,直接重写validate()方法即可.使用validate()方法可以对用户请求的多个Action方法进行验证,但其验证的逻辑是 ...

  5. Struts2数据验证与使用Java代码进行数据验证

    Struts2数据验证 使用Java代码进行数据验证 重写ActionSupport的validate()方法 对Action类的中所有请求处理方法都会进行验证! 对Action类的数据属性进行检查, ...

  6. struts2使用验证文件实现校验

    原创 struts2框架提供了一种基于验证文件的输入验证方式,将验证规则保存在特定的验证文件中. 验证文件的命名规则 一般情况下,验证文件的命名规则是:Action类名-validation.xml. ...

  7. struts2的验证

    1.原理 当浏览器向服务器提交表单数据时,在服务器端需要对表单数据的有效性进行校验. “校验方法”会在“业务方法”之前调用. 2.实现验证的两种方式 struts2校验的两种实现方法: 1. 手工编写 ...

  8. C# 中参数验证方式的演变

    一般在写方法的时候,第一步就是进行参数验证,这也体现了编码者的细心和缜密,但是在很多时候这个过程很枯燥和乏味,比如在拿到一个API设计文档的时候,通常会规定类型参数是否允许为空,如果是字符可能有长度限 ...

  9. SQLSERVER误删除了Windows登录用户验证方式使用Windows身份验证的解决方法

    SQLSERVER误删Windows登录用户验证方式使用Windows身份验证的解决方法 今天看到这篇文章:没有了SA密码,无法Windows集成身份登录,DBA怎么办? 想起来之前着急哥问我的一个问 ...

随机推荐

  1. 如何用Navicat for MySQL 将mysql中的数据库导出,导入。

    数据库导出 1.双击要导出的数据库,右键选转储SQL文件...,选择要保存的文件夹. 2.点击开始后,开始导出. 数据库导入 1.新建数据库,数据库的名字必须和导入的数据库文件一致. 2.在新建的数据 ...

  2. BJFU 1440 fudq的ACM

    矩阵快速幂 #include<cstdio> #include<algorithm> using namespace std; ; const int INF =1e9; ; ...

  3. js继承实现

    JS实现继承可以分为:对象冒充和原型链继承 其中对象冒充又包括:临时变量,call 和 apply 临时变量方法: function Person(name,sex){ this.name = nam ...

  4. UVALive - 3026 Period kmp next数组的应用

    input n 2<=n<=1000000 长度为n的字符串,只含小写字母 output Test case #cas 长度为i时的最小循环串 循环次数(>1) 若没有则不输出 做法 ...

  5. Python基础篇-day3

    主要内容:字典 集合 文件处理 字符编码 1.字典dict简介dict就是key value值,索引有意义,数据无序 key定义规则:a:不可变--数字.字符串.元组(可变--列表.字典)b:不能重复 ...

  6. freemarker遍历list中的map

    前台: <select id="jq" name="jq" class="tsui" data-required="true ...

  7. 《Windows驱动开发技术详解》之驱动程序的同步处理

    中断请求级 中断请求被分为软件中断和硬件中断两种,这些中断都映射成不同级别的中断请求级.每个中断请求都有各自的优先级别,正在运行的线程随时都可以被中断打断,进入到中断处理程序.优先级高的中断来临时,处 ...

  8. 已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭

    已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭 引用:   http://www.cnblogs.com/maxao/archive/2011/03/18/19881 ...

  9. Internet History, Technology and Security (Week1)

    Week1. History: Dawn of Electronic Computing War Time Computing and Conmmunication Keywords: Electro ...

  10. thinkphp的model模型的设计经验总结

    关于模型:跟上篇文章thinkphp的目录结构设计经验总结写控制器一个道理:为了尽量避免改动到框架: 首先我们是要有一个BaseModel.class.php作为我们的基础model: 我会在Base ...