zoukankan      html  css  js  c++  java
  • struts 数据验证指定方法(使用xml文件)

    Struts数据效验

    1.表单数据的验证:

             前台验证:主要是通过JS验证, 表达数据是否合法!

             后台验证:通过后台java代码进行验证!

                        Struts也提供了数据效验的方式!

    2.Struts数据效验, 通过拦截器完成:

             <interceptor

    name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/>

    3.代码方式验证Action中指定的方法:

    写验证方法命名规则:

             validate + 要验证的方法名

    如:

             public void validateRegister() {

        只会验证当前action的register方法!

    4.XML方式验证Action中所有的方法:

    总结代码方式验证:

             繁琐,设计很多重复的验证逻辑!例如:非空验证、数值验证、email、日期等。

    Struts对于常用的验证,进行了封装,即提供了验证器, 验证指定的常用业务逻辑!

    路径:

    xwork-core-2.3.4.1.jar/com.opensymphony.xwork2.validator.validators/default.xml

    <?xml version="1.0" encoding="UTF-8"?>

    <!DOCTYPE validators PUBLIC

            "-//Apache Struts//XWork Validator Definition 1.0//EN"

            "http://struts.apache.org/dtds/xwork-validator-definition-1.0.dtd">

     

    <!-- START SNIPPET: validators-default -->

    <validators>

        <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"/>

    </validators>

    <!--  END SNIPPET: validators-default -->

    5.

    如果写xml,从而定义验证规则:

             1)XML文件名称语法: ActionClassName-validation.xml

                      注意:此xml需要与当期要验证的action在同一个目录:

                      举例:UserAction-validation.xml

             2) 写XML

    <?xml version="1.0" encoding="UTF-8"?>

    <!DOCTYPE validators PUBLIC

          "-//Apache Struts//XWork Validator 1.0.3//EN"

          "http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">

     

    <validators>

      

       <!-- 验证的每一个字段用field表示 -->

       <field name="user.userName">

         <!-- 指定使用的验证器 -->

         <field-validator type="requiredstring">

            <!-- 验证失败的错误提示信息 -->

            <message>用户名不能为空!</message>

         </field-validator>

       </field>

      

       <!-- 验证pwd -->

       <field name="user.pwd">

        

         <!-- 非空 -->

         <field-validator type="requiredstring">

            <message>密码不能为空!</message>

         </field-validator>

        

         <!-- 长度 -->

         <field-validator type="stringlength">

            <param name="minLength">6</param>

            <param name="maxLength">8</param>

            <message>密码必须为6-8位!</message>

         </field-validator>

       </field>

      

       <!-- 验证日期 -->

       <field name="user.birth">

         <field-validator type="date">

            <message>日期格式不对!</message>

         </field-validator>

       </field>

      

       <!-- 验证Email -->

       <field name="user.email">

         <field-validator type="email">

            <message>邮箱格式错误!</message>

         </field-validator>

       </field>

      

    </validators>     

         

         

    7.XML方式验证Action中指定的方法:

    与上面xml验证方式大致相同: 验证xml文件内容不变;

    文件命名:

             语法:ActionClassName-ActionName-validation.xml

             举例:UserAction-user_register-validation.xml

                        验证UserAction中的register方法

    8.验证总结

             代码:

                 重写validate()   ,  验证action所有方法

                       Validate方法名(),  验证指定“方法名”的方法

             Xml:

                      验证所有方法: ActionClassName-validation.xml

                      验证指定方法: ActionClassName-actionName-validation.xml

             代码验证,

                      比较灵活,可以满足所有的需求.

                      比较繁琐,要写重复的验证判断逻辑!

                      适合: 表单字段较少的情况用!

             XML验证:

                      通用,但不够灵活; 可以验证特定简单的业务。

                      适合: 验证表单字段较多,可以大大简化代码!

                                (配置文件过多)

    9.验证错误处理

    Struts在进行数据效验的时候,验证失败,会返回input视图,要求我们要在struts.xml中配置input视图对应的错误页面!

    配置:

    Struts.xml

    <!-- 注册失败跳转到注册页面,显示失败信息 -->

         <global-results>

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

         </global-results>

    Jsp显示错误

    • 方式1:显示所有错误

    <%@taglib uri="/struts-tags" prefix="s" %>

      <!-- 显示的是struts在运行时期产生的所有错误 -->

      <s:fielderror></s:fielderror>

    • 方式2:显示指定的错误

    <!-- 修改struts标签默认的样式: 不让换行 -->

       <style type="text/css">

       ul{

         display: inline;

       }

       ul li{

         display: inline;

         color: red;

       }

       </style>

    显示指定的错误:

    <s:fielderror fieldName="user.userName"></s:fielderror>

    • 方式3: 修改标签定义的模板

    找到fielderror标签定义的模板文件:

    Struts-core.jar emplatesimple fielderror.ftl

    把修改后的fielderror.ftl文件,放到src/ template/ simple/ fielderror.ftl

    这样标签显示的样式就修改了!

    2. Struts 简单UI标签

    <!-- 服务器标签 : 最终别解析为html标签-->

      <s:form action="/user_login" method="post" name="frmLogin" id="frmLogin" theme="simple">

         

          用户名:<s:textfield name="user.name"></s:textfield>

          密码:<s:textfield name="user.pwd"></s:textfield>

          <s:submit value="登陆"></s:submit>

      </s:form>

    注意:

             给form指定主题,form下所有的表单元素都应用此主题!

    对于struts标签默认的主题样式:default.xml/struts.ui.theme=xhtml

    可以通过常量修改, 改为简单主题:

             <!-- 修改主题 (当前项目所有的标签都用此主题)-->

       <constant

    name="struts.ui.theme" value="simple"></constant>

  • 相关阅读:
    第二十节:Scrapy爬虫框架之使用Pipeline存储
    第十九节:Scrapy爬虫框架之Middleware文件详解
    第十八节:Scrapy爬虫框架之settings文件详解
    第十七节:Scrapy爬虫框架之item.py文件以及spider中使用item
    第十六节:Scrapy爬虫框架之项目创建spider文件数据爬取
    第一节:python提取PDF文档中的图片
    第十五节:Web爬虫之selenium动态渲染爬取
    H5移动开发底部导航-博客园老牛大讲堂
    ajax跨域通信-博客园老牛大讲堂
    博客园模板2--博客园老牛大讲堂
  • 原文地址:https://www.cnblogs.com/yimian/p/7818091.html
Copyright © 2011-2022 走看看