struts2和jquery_validator简单使用

来源:互联网 发布:百度云管家for mac 编辑:程序博客网 时间:2024/05/16 15:48
项目中时常会用到一些验证手段...由于在开发前需要对一些技术的定位!所以一般选择固定的验证框架和技术.
我在前台验证中使用的是jquery_validator.这是个容易上手的框架.个人感觉它和struts2结合在一起非常不错.下面讲下使用的过程.
准备的jar包:struts2可以到
http://struts.apache.org/download.cgi下载
juery_validator可以到
http://plugins.jquery.com/project/validate下载
jquery_validator的介绍:
一.默认校验规则
(1)required:true 必输字段
(2)remote:"check.php" 使用ajax方法调用check.php验证输入值
(3)email:true 必须输入正确格式的电子邮件
(4)url:true 必须输入正确格式的网址
(5)date:true 必须输入正确格式的日期
(6)dateISO:true 必须输入正确格式的日期(ISO),例如:2009-06-23,1998/01/22 只验证格式,不验证有效性
(7)number:true 必须输入合法的数字(负数,小数)
(8)digits:true 必须输入整数
(9)creditcard: 必须输入合法的信用卡号
(10)equalTo:"#field" 输入值必须和#field相同
(11)accept: 输入拥有合法后缀名的字符串(上传文件的后缀)
(12)maxlength:5 输入长度最多是5的字符串(汉字算一个字符)
(13)minlength:10 输入长度最小是10的字符串(汉字算一个字符)
(14)rangelength:[5,10] 输入长度必须介于 5 和 10 之间的字符串")(汉字算一个字符)
(15)range:[5,10] 输入值必须介于 5 和 10 之间
(16)max:5 输入值不能大于5
(17)min:10 输入值不能小于10

默认的提示在jquery_validate.js源码中可以看到是英文的提示:
messages: {.....}
可以自己进行修改.不过jquery_validate本来就提供了各个语言的包就在下载的jquery.validate.zip中localization包下.使用中文可以导入messages_cn.js;

下面是例子的开始:
整个项目的部署过程就不说了。下面会有例子上传
讲些重点.
reg.jsp:
Java代码 复制代码 收藏代码
  1. <link href="css/jquery_validate.css" rel="stylesheet" type="text/css"/>   
  2. <script type="text/javascript" src="js/jquery.js"></script>   
  3. <script type="text/javascript" src="js/jquery_validate.js"></script>   
  4. <script type="text/javascript" src="js/jquery.metadata.js"></script>   
  5. </head>   
  6. <script type="text/javascript">   
  7. $(function() {   
  8.     $("#jvForm").validate();   
  9. });   
  10. </script>   
  11. <body>   
  12. <form action="" method="post" id="jvForm">   
  13. <table>   
  14. <tr>   
  15. <td>name:</td>   
  16. <td><input type="text" name="bean.name"  class="{required:true,remote:'admin/core/ajax/checkUserName.action',messages:{remote:'用户名已存在!'}}"/></td>   
  17. </tr>   
  18. <tr>   
  19. <td>password:</td>   
  20. <td><input type="password" name="bean.password" class="required"/></td>   
  21. </tr>   
  22. <tr>   
  23. <td colspan="2"><input type="submit" value="提交"/></td>   
  24. </tr>   
  25. </table>   
  26. </form>  

首先引入jquery_validate.css.对提示的内容进行css格式的修改.
jquery.metadata.js可以提供
使用class="{}"的方式,可以使用如下的方法,修改提示内容:
class="{required:true,minlength:5,messages:{required:'请输入内容'}}"在使用equalTo关键字时,后面的内容必须加上引号,如下代码:
class="{required:true,minlength:5,equalTo:'#password'}"
它的其他几种表现方式就不介绍了.因为各个感觉这种表现形式是最好用的.
用户名的检测中我们做了一个模拟检验用户名是否存在(这种操作在项目中也是比较常见.对于一些名字不可以重复的进行提示).我们访问了checkName.action.下面看看相应的Action实体:
AdminAjaxAct
Java代码 复制代码 收藏代码
  1. public class AdminAjaxAct implements Action{   
  2.        
  3.   
  4.     /**  
  5.      * 判断前台用户注册  
  6.      *   
  7.      * @return  
  8.      */  
  9.     public String checkUserName() {   
  10.         String username = bean.getName();   
  11.         boolean b = true;   
  12.         if (StringUtils.isBlank(username)) {   
  13.             b = false;   
  14.         }   
  15.            
  16.         if (b) {   
  17.             b = "test".equals(username);   
  18.         }   
  19.         //如果用户名存在.就代表检验用户存在  
  20.         //所以用户不能提交  
  21.         return renderText(b ? "false" : "true");   
  22.     }   
  23.   
  24.     /**  
  25.      * 绕过Template,直接输出内容的简便函数.对常用的数据进行抽取.提高 
  26.             *提高重用性  
  27.      */  
  28.     protected String render(String text, String contentType) {   
  29.         try {   
  30.             HttpServletResponse response = ServletActionContext.getResponse();   
  31.             response.setContentType(contentType);   
  32.             response.getWriter().write(text);   
  33.         } catch (IOException e) {   
  34.         }   
  35.         return null;   
  36.     }   
  37.   
  38.     /**  
  39.      * 直接输出字符串.  
  40.      */  
  41.     protected String renderText(String text) {   
  42.         return render(text, "text/plain;charset=UTF-8");   
  43.     }   
  44.   
  45.     private Admin bean;   
  46.   
  47.   
  48.   
  49.     public Admin getBean() {   
  50.         return bean;   
  51.     }   
  52.   
  53.   
  54.   
  55.     public void setBean(Admin bean) {   
  56.         this.bean = bean;   
  57.     }   
  58.   
  59.   
  60.   
  61.     @Override  
  62.     public String execute() throws Exception {   
  63.         return SUCCESS;   
  64.     }   
  65.        
  66.        
  67. }  

StringUtils:apache提供的工具包(挺好用).因为要符合jquery_validator的形式所以输出的要为true.false方便以信息的形式进行提示.

从中就可以感觉到.在使用jquery_validator的时候使用struts2的OGNL表达式的原型完成可以整在一起.他传递参数也同样是使用是将对象的引用值用点串联起来.如bean.name;
jquery_validator也可以给用户自己扩展可以参考
http://www.f6n.net/blog/web/200901129415.html
struts2的包自己下载咯
测试时候使用用户名输入test提示用户名已被使用.这可以应用到数据库
  • struts2_jquery_volidator.rar (39.3 KB)
  • 下载次数: 62
  • commons-lang-2.4.jar (255.7 KB)
  • 下载次数: 20
原创粉丝点击