spring mvc 校验框架

来源:互联网 发布:构造函数 java 编辑:程序博客网 时间:2024/05/19 12:40

       Spring 3.0拥有自己独立的数据校验框架,同时支持JSR 303标准的校验框架。


   JSR 303是Java为Bean数据合法性校验所提供的标准框架,它已经包含在Java EE 6.0中。JSR 303通过在Bean属性上标注类似于@NotNull、@Max等标准的注解指定校验规则,并通过标准的验证接口对Bean进行验证。
      可以通过http://jcp.org/en/jsr/detail?id=303了解JSR 303的详细内容。

  

    使用到的注解  



 使用到的jar包

  



1:首先

   在web.xml中 配置 spring.xml 文件和 springmvc.xml文件


<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"><!-- 配置spring.xml 文件 --><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:/spring.xml</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><!-- 解码过滤器 --><filter><filter-name>utf</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>utf</filter-name><url-pattern>/*</url-pattern></filter-mapping>      <servlet>  <servlet-name>springDispatcherServlet</servlet-name>  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>    <!-- 加载 springmvc 文件 -->  <init-param>  <param-name>contextConfigLocation</param-name>  <param-value>classpath:/springmvc.xml</param-value>  </init-param>      <load-on-startup>1</load-on-startup>    </servlet><servlet-mapping><servlet-name>springDispatcherServlet</servlet-name><url-pattern>/</url-pattern></servlet-mapping>  <welcome-file-list>    <welcome-file>index.jsp</welcome-file>  </welcome-file-list></web-app>


2.springmvc.xml 中加上 

<context:component-scan base-package="包名"></context:component-scan>

spring.xml里可以什么都没有,但是必须要写。


首先 ,验证分为 2种。

   1:声明式验证

   2:编程式验证

  


声明式验证 :

  直接在 entity类,需要验证的字段上面加对应的注解。


例 

@NotEmpty(message="错误消息")private String userName;@Pattern(regexp = "\\d{6}",message="错误消息")private String password;

编程式验证:

首先只要,spring可以自动给形参的变量对象进行实例化,如果想对该对象的属性进行校验,那么在该对象之前 要加上 @Valid


如 


@RequestMapping("/映射url")public String verify(@Valid Register regis,BindingResult binding){//编程式验证 如果密码不同  增加一个异常if(regis.getAgPassword()==null||!regis.getPassword().equals(regis.getAgPassword())){
binding.addError(new FieldError("register", "agPassword", message));}//如果 有错误 返回原页if(binding.hasErrors()){return "原来页面用于显示验证消息";}return "成功页面 ";}


jsp页面:

  

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><title>spring verify</title></head><body><%--<a href="${pageContext.request.contextPath}/verify!I18n?request_locale=zh_CN"><s:property value="%{getText('chinese')}"/></a>     <a href="${pageContext.request.contextPath}/verify!I18n?request_locale=en_US"><s:property value="%{getText('english')}"/></a>--%><table> <form action="${pageContext.request.contextPath}/verify.action" method="post" enctype="multipart/form-data">  <tr><td>姓名:</td><td><input type="text" name="userName"/></td><td><font color="red"><form:errors path="register.userName"></form:errors></font></td></tr>   <tr><td><input type="submit" value="提交"/></td></tr> </form> </table> </body></html>


<form:errors path="register.userName"></form:errors> 用于接收 校验消息 



path对应是对象名.属性名。 对象名小写。



接收消息如果做国际化 



在spring.xml中 加上 



<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource"><property name="basename" value="/lg"></property></bean>

其中value值对应的就是国际化资源文件的前缀名。


在springmvc.xml文件中配置 


<!-- springmvc默认的验证 就是实例化了 一个LocalValidatorFactoryBean的实例 其中没有实现国际化         手工创建一个该类的实例 并且注入 messageSouce 才能国际化    -->   <bean id="factoryBean" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">      <property name="validationMessageSource" ref="messageSource"></property>   </bean>

ref引入对应加载 
ResourceBundleMessageSource的实例。
加入消息转换器(必须)
<mvc:annotation-driven validator="factoryBean"></mvc:annotation-driven>


validator引入 
LocalValidatorFactoryBean的实例

jsp页面中 显示错误验证消息使用:

<%@taglib uri="http://www.springframework.org/tags" prefix="s"%>
           <s:message code="资源文件的key">

entity类使用 

@NotEmpty(message="{unull}")private String userName;@Pattern(regexp = "\\d{6}",message="{sixpassword}")private String password;

 使用{key值} 来获取资源文件中对应的value值



编程验证里的国际化 

@RequestMapping("/映射url")public String verify(@Valid Register regis,BindingResult binding ,Locale locale){//编程式验证 如果密码不同  增加一个异常if(regis.getAgPassword()==null||!regis.getPassword().equals(regis.getAgPassword())){
//获取 当前国际化的对应keyString message= source.getMessage("notpassword", null, locale);
binding.addError(new FieldError("register", "agPassword", message));}//如果 有错误 返回原页if(binding.hasErrors()){return "原来页面用于显示验证消息";}return "成功页面 ";}