struts2_03表单校验ognl国际化

一、用户输入验证
 1、编程方式:
  动作类中的所有方法进行验证:
  
   步骤:
   a、动作类继承ActionSupport
   b、覆盖调用public void validate()方法
   c、在validate方法中,编写不符合要求的代码判断,并调用父类的addFieldError(String fieldName,String errorMessage)
    如果fieldError(存放错误信息的Map)有任何的元素,就是验证不通过,动作方法不会执行。
    Struts2框架会返回到name=input的result
   d、在name=input指定的页面上使用struts2的标签显示错误信息。<s:fielderror/> 或 ${errors.名字}
  
  动作类中指定的方法进行验证:
   编写步骤与上面相同
   
   验证方法书写有要求:
    public void validateXxx()   Xxx代表的是要验证的动作方法名,其中要把动作方法名的首字母变为大写。
    
 
 2、基于XML配置文件的方式:
  动作类中的所有方法进行验证:
   在动作类的包中,建立一个名称为:动作简单类名-validation.xml ,比如要验证的动作类名是UserAction   UserAction-validation.xml
   内容如下:
   <?xml version="1.0" encoding="UTF-8"?>
   <!DOCTYPE validators PUBLIC
     "-//OpenSymphony Group//XWork Validator 1.0.3//EN"
     "http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd"><!--dtd在xwork包下-->
   <validators>
    <field name="username"><!--jsp中可以通过${errors.username}或<s:fielderror></s:fielderror>输出错误信息-->
     <!-- 内置验证器都是定义好的,在xwork-core.jar com.opensymphony.xwork2.validator.validators包中的default.xml文件中 -->
     <field-validator type="requiredstring"><!-- 不能为null或者""字符串,默认会去掉前后的空格 -->
      <message>用户名不能为空</message>
     </field-validator>
    </field>
   </validators>
  动作类中指定的方法进行验证:
   配置文件的名称书写有一定要求。
     动作类名-动作名(配置文件中的动作名)-validation.xml
     UserAction-user_add-validation.xml
struts2提供的校验器列表

系统提供的校验器如下:
required (必填校验器,要求field的值不能为null)
requiredstring (必填字符串校验器,要求field的值不能为null,并且长度大于0,默认情况下会对字符串去前后空格)
stringlength(字符串长度校验器,要求field的值必须在指定的范围内,否则校验失败,minLength参数指定最小长度,maxLength参数指定最大长度,trim参数指定校验field之前是否去除字符串前后的空格)
regex(正则表达式校验器,检查被校验的field是否匹配一个正则表达式.expression参数指定正则表达式,caseSensitive参数指定进行正则表达式匹配时,是否区分大小写,默认值为true)
int(整数校验器,要求field的整数值必须在指定范围内,min指定最小值,max指定最大值)
double(双精度浮点数校验器,要求field的双精度浮点数必须在指定范围内,min指定最小值,max指定最大值)
fieldexpression(字段OGNL表达式校验器,要求field满足一个ognl表达式,expression参数指定ognl表达式,该逻辑表达式基于ValueStack进行求值,返回true时校验通过,否则不通过)
email(邮件地址校验器,要求如果field的值非空,则必须是合法的邮件地址)
url(网址校验器,要求如果field的值非空,则必须是合法的url地址)
date(日期校验器,要求field的日期值必须在指定范围内,min指定最小值,max指定最大值)
conversion(转换校验器,指定在类型转换失败时,提示的错误信息)
visitor(用于校验action中的复合属性,它指定一个校验文件用于校验复合属性中的属性)
expression(OGNL表达式校验器,expression参数指定ognl表达式,该逻辑表达式基于ValueStack进行求值,返回true时校验通过,否则不通过,该校验器不可用在字段校验器风格的配置中)


2. 校验器的使用例子

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>

email:邮件地址校验器
<field-validator type="requiredstring">
    <param name="trim">true</param>
    <message>邮箱不能为空</message>
</field-validator>
<field-validator type="email">
    <message>邮件格式不正确</message>
</field-validator>

regex:正则表达式校验器
<field-validator type="regex">
     <param name="expression"><![CDATA[^1[358]\d{9}$]]></param>
     <message>手机号格式不正确!</message>
</field-validator>

int:整数校验器
<field-validator type="int">
 <param name="min">1</param>
 <param name="max">150</param>
 <message>年龄必须在1-150之间</message>
</field-validator>

字段OGNL表达式校验器
<field name="imagefile">
 <field-validator type="fieldexpression">
  <param name="expression"><![CDATA[imagefile.length() <= 0]]></param>
  <message>文件不能为空</message>
 </field-validator>
</field>

3、自定义基于XML的验证器
  a、编写一个类,继承FieldValidatorSupport类。
  b、在public void validate(Object object)编写你的验证逻辑
    不符合要求的就向fieldErrors中放消息
  c、一定注册你的验证器才能使用
    在WEB-INF/classes目录下建立一个名称为validators.xml的配置文件,内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<!-- 注册自定义的验证器 -->
<!DOCTYPE validators PUBLIC
        "-//OpenSymphony Group//XWork Validator Config 1.0//EN"
        "http://www.opensymphony.com/xwork/xwork-validator-config-1.0.dtd">
<validators>
    <validator name="strongpassword" class="cn.itcast.validators.StrongPasswordValidator"/>
</validators>
  d、日后就可以像使用Struts2提供的16个验证器方式去使用了。
  
二、Struts2对于i18n的支持
 全局资源文件/包范围资源文件/动作类的资源文件
 全局资源文件:放到WEB-INF/classes目录下
 包范围资源文件:服务于Java类中的包下的动作类的。
   取名:package_语言_国家.properties
 
 动作类的资源文件:放到与动作类相同的包中
   取名:动作类名_语言_国家.properties
   
   
 jsp中如何读取国际化的消息
 动作类中如何读取国际化的消息
三、OGNL表达式:
 OGNL是从ActionContext中获取数据的。
 
 ActionContext的结构:
  ValueStack:
   List:动作类放在此处。取存放在ValueStack中的root的对象的属性,直接写即可
   
   访问以下内容中的对象要使用#+(范围)session
  application:ServletContext中的那个Map
  session:HttpSession中的那个Map
  request:ServletRequest中的那个Map
  parameters:请求参数的那个Map。(如同EL表达式的paramValues内置对象)
  attr:相当于PageContext的findAttribute方法。${username}
 小技巧:在页面中使用<s:debug/>查看上下文中的对象

 

 

一)OGNL简介
   (1)回顾EL的作用
 A)能获取域对象(page/request/session/application)中的数据,例如:${sessionScope.username} 
 B)运算和判断,例如:${10 * 10},${!empty sessionScope.username?sessionScope.username:'游客'}
 C)EL函数,例如:${fn:toUpper('www.itcast.cn')}
   (2)OGNL的作用(对象图导航语言,struts2专用的标记语言,比EL更强大)      
  A)获取ActionContext中的数据
  B)集合操作,即访问list,map
   (3)理解ActionContext对象 
 A)ActionContext对象是struts2的数据中心,在一次符合/*模式的请求到来时,框架负责创建,放置在request域
    对象中。
        B)ActionContext对象可以分为如下几个子对象。
    参见<<ActionContext对象的六个子对象.JPG>>
        C)ActionContext有一个非常重要和特殊的对象,叫值栈,它是Action的数据中心,在一次符合/*模式的请求到来时,
           框架负责创建,放置在request域对象中。
  D)值栈分为二个部分:
    》对象栈(List集合)
      Action的实例
      Action的属性   
  
    》Map栈(Map集合) 
      通过ValueStack的API操作的对象
      
  page->request->ValueStack->session->application->
  如果都找不到,返回空白字符串
  如果找到了,不会再继续查找
  在struts2中,不提倡使用request来存内容,而使用ValueStack来替换requset对象
     
//演示向ActionContext对象中六个子对象存数据
public class BaseAction extends ActionSupport{
 public String execute() throws Exception {

  //获取struts2的数据中心
  ActionContext actionContext = ActionContext.getContext();
  
  /*向request中存入数据
  ServletActionContext
   .getRequest()
   .setAttribute("username","requestMap");
  */ 
  
  //向sessionMap中存入数据
  //actionContext.getSession().put("username","sessionMap");
  
  //向applicationMap中存入数据
  //actionContext.getApplication().put("username","applicationMap");
  
  //向ValueStack中存入数据
  //actionContext.getValueStack().set("username","ValueStack");
  
  return this.SUCCESS;
 }
}

    <%@ page language="java" pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <body>
  <%
   //pageContext.setAttribute("username","page");
  %>
  获取ActionContext对象中六个子对象的数据<br/>
  requestMap:<s:property value="#request.username"/><br/>   
  sessionMap:<s:property value="#session.username"/><br/>   
  applicationMap:<s:property value="#application.username"/><br/>   
  ValueStack:<s:property value="username"/><br/>  
  parameters:<s:property value="#parameters.username"/><br/>
  <b>attr:<s:property value="#attr.username"/></b> 
 </body>
</html>

二)OGNL的4种符号用法
   *(1)#
 >>访问ActionContext对象
 >>访问集合Map:#{'male':'[男]','female':'[女]'}
 >>访问集合List
   A)集合的投影:userList.{username,JavaBean的某个属性值}
   B)集合的过滤:userList.{?#this.age>22}
         userList.{^#this.age>22}
                       userList.{$#this.age>22}.{?#this.gender=="男"}
         ?#表示所有对象  
         ^#表示第一个对象  
         $#表示最后一个对象 
   this表示当前迭代的这个对象 
          C)集合的投影和过滤:userList.{?#this.age>22}[0]
        [0]表示符合条件的第一个对象 
               [1]表示符合条件的第二个对象 

 什么情况下使用#:
 A)非值栈
 B)获取JavaBean属性值
  
   (2)%{}:
  >><s:textfield label="%{usernameTIP变量}" name="username"/>
  >><s:textfield label="%{'usernameTIP'常量}" name="username"/>
   (3)${}不是EL:
  >><field-validator type="double">
  <param name="minInclusive">4000</param>
  <param name=" maxInclusive">6000</param>
  <message>薪水必须介于${minInclusive}到${maxInclusive}之间</message>
    </field-validator> 
    ${}可以访问xml本身的数据
         >><param name="contentDisposition">attachment;filename=${filename}</param> 
    ${}也可以访问Action实例变量,前提Action一定要对该实例变量提供getXxx()方法
   (4)访问集合List或{}
         >>value='{"AA","BB","CC","DD"}'
         >><s:property value="stringList.isEmpty"/>
         >><s:property value="stringList.size"/>

  在迭代List或数组时,#可要可不要

三)struts2常用标签介绍 
    1)标签(M) :为了显示出某种特殊的效果,struts2对普通进封装后产生的对象,叫标签。
    struts2标签底层,都是处理类,例如:<s:textfield/> 

    2)模板(N) :将所有风格显示相类型的标签,形成一个集合,该集合就叫做模板。 
    1个模板对应N个标签

    3)主题(1) :将N个模板所表现出来的内容,形成一个集合,该集合就叫做主题。
    1个主题对应N个模板   

    4)struts2的四类主题
       A)simple主题:checkbox,无<table>,灵活  
       B)xhtml主题:checkbox(struts2默认主题)有<table>
       C)css_xhtml主题:checkbox,无<table>,用div替换<table>
       D)ajax主题:checkbox        

    5)修改主题的三种方式
       A)在某个表单标签中修改,例如:<s:textfield label="用户名" name="username" theme="simple"/> 
       B)在<s:form>标签中使用theme,争对整个表单中的所有表单项元素<s:form theme="simple"/>
       C)在struts.property文件中,覆盖系统的整体风格,struts.ui.theme=simple 
       当A,B,C同时作用某一个表单标签时,A起决定作用 

    6)标签的四种作用
       A)[布局]
       B)表单项数据回显  
       C)错误信息显示   
       D)国际化          

    7)常用标签
      *>>s:fielderror
      *>>s:property
      *>>s:text

      *>>s:form
      *>>s:textfield
      *>>s:password
      *>>s:submit
      *>>s:reset
      *>>s:hidden   
      *>>s:textarea
         当需要将jquery加入进来时,需要注意二点:
  A)引用jquery的路径,使用绝对路径,例如:/day34/js/jquery-1.8.2.min.js
  B)定位某个标签时,不能使用struts2标签,只能使用普标签
      *>>s:radio【listValue页面中显示的值,listKey页面中隐藏的值】
      *>>s:select
      *>>s:checkboxlist
      *>>s:property
       >>s:bean
       >>s:param
       >>s:url
       >>s:set
       >>s:include
       >>s:date
      *>>s:if-s:elseif-s:else
      *>>s:iterator
       >>s:sort【实现Comparator接口】

你可能感兴趣的:(Ognl,i18n,表单校验)