Struts Validator验证器使用指南

  1. 验证器:
  2. 从0.5版,验证器在一些form中就已经实现了,他最初包含在开发人员包中,后来核心代码挪到JakartaCommons包中和Struts特别扩展中作为Struts1.1的一部分。许多开发者为方便一直使用struts验证器,这篇文档首先概述验证器的核心功能性,然后大概介绍在struts1.1中的变化和新增功能。
  3. 如果你配置好验证器插件,你应该扩展ValidatorForm而不是ActionForm,以便它能加载你的Validator资源。他根据struts-config.xml文件中的action的name属性为当前form的调用相应的验证器,因此在validator-rules.xml中的form元素的名称属性应该与action的name属性值相匹配。
  4. 另外一种选择是扩展ValidatorActionForm而不是ValidatorForm,ValidatorActionForm使用struts-config.xml中action的path属性,所以path属性的值相应的应该与validator-rules.xml中的Form的name属性匹配。
  5. 一个分离的action可以定义给多页form的每个页面,而且验证规则可以与action关联而不是与页码,就像验证范例中的多页form范例那样。
  6. 国际化
  7. 在validator-rules.xml文件中form的验证规则可以组织为FormSet。FormSet有与java.util.Locale类相应的属性:如语言,国家以及变量型属性,如果他们未定义,FormSet将把它设置为默认值。一个FormSet也可以有关联的常量。另外还可以定义与FormSet同一级别的全局global元素,他与FormSet同样也有常量。
  8. 注意:你必须在国际化的FormSet前声明一个没有国际化的默认FormSet。这样如果Validator没有找到locale时可以有一个默认版本。
  9. 可插入验证器的默认错误信息值可以被msg元素覆盖。所以为mask验证器生成错误信息的替代方法就是使用msg属性,如果字段的name属性与验证器的name属性匹配,那末将使用字段的msg属性。
  10. errormessages的可以设置arg0-arg3等参数元素。如果没有设置arg0-arg3的name属性,errormessages将使用他们作为默认的构建参数值。如果设置了name属性,你就可以把参数指定给一特定的可插入验证器,然后这些参数将在构造错误信息时被使用。
  11. <field
  12. property="lastName"
  13. depends="required,mask">
  14. <msg
  15. name="mask"
  16. key="registrationForm.lastname.maskmsg"/>
  17. <arg0key="registrationForm.lastname.displayname"/>
  18. <var>
  19. <var-name>mask</var-name>
  20. <var-value>^[a-zA-Z]*$</var-value>
  21. </var>
  22. </field>
  23. 默认的arg0-arg3元素将在消息资源中查找相应的key,如果资源属性设为false,她将把值直接传进去,而不从消息资源中查找。注意1.1版本中,你必须为每个模块中明确地定义在验证中用到的消息资源,否则将使用top-level资源。
  24. <field
  25. property="integer"
  26. depends="required,integer,intRange">
  27. <arg0key="typeForm.integer.displayname"/>
  28. <arg1
  29. name="range"
  30. key="${var:min}"
  31. resource="false"/>
  32. <arg2
  33. name="range"
  34. key="${var:max}"
  35. resource="false"/>
  36. <var>
  37. <var-name>min</var-name>
  38. <var-value>10</var-value>
  39. </var>
  40. <var>
  41. <var-name>max</var-name>
  42. <var-value>20</var-value>
  43. </var>
  44. </field>
  45. 常量/变量
  46. 全局的常量可以在全局标签中定义,FormSet/本地常量能在formset标签中创建。常量当前仅仅是代替字段的property属性,字段的var元素的value属性,字段的msg元素的key属性,字段的arg0-arg3元素的key属性。字段的变量也可以在arg0-arg3元素中被代替(例如:${var:min}))。替换的顺序是FormSet/Locale常量第一,全局的常量第二,
  47. argelements变量最后。
  48. <global>
  49. <constant>
  50. <constant-name>zip</constant-name>
  51. <constant-value>^/d{5}(-/d{4})?$</constant-value>
  52. </constant>
  53. </global>
  54. <field
  55. property="zip"
  56. depends="required,mask">
  57. <arg0key="registrationForm.zippostal.displayname"/>
  58. <var>
  59. <var-name>mask</var-name>
  60. <var-value>${zip}</var-value>
  61. </var>
  62. </field>
  63. 验证器可以使用字段下面的变量部分来存储变量,这些变量通过字段的getVar((Stringkey)方法取得。
  64. <field
  65. property="integer"
  66. depends="required,integer,intRange">
  67. <arg0key="typeForm.integer.displayname"/>
  68. <arg1
  69. name="range"
  70. key="${var:min}"resource="false"/>
  71. <arg2
  72. name="range"
  73. key="${var:max}"resource="false"/>
  74. <var>
  75. <var-name>min</var-name>
  76. <var-value>10</var-value>
  77. </var>
  78. <var>
  79. <var-name>max</var-name>
  80. <var-value>20</var-value>
  81. </var>
  82. </field>
  83. 使用validwhen设计复杂的验证
  84. 使用validwhen来设计复杂验证的一个经常的要求就是根据一个字段验证另外一个字段(比如,如果你要用户两次输入口令来确认值口令一致),另外一个就是表单中的一个字段只有另外一个字段有确定值的时候才是必须输入的。新的validwhen验证规则将很快被包含在1.1后的STRUTS版本中,她就是用来处理这种情况的。
  85. validwhen规则处理单个的变量字段,叫测试。这变量的值是一个布尔的表达式,如果验证有效则它必须为真。可以包含这种变量的表达式有:
  86. u单引号或双引号字符串literals,
  87. u十进制、十六进制、八进制的Integerliterals,
  88. unullnull和空字符串匹配,
  89. u其它可以用属性名引用的form字段,例如customerAge,
  90. u可以在外部因用得索引字段,例如childLastName[2],
  91. u可以默认implicit因用得索引字段,例如childLastName[],她将作为被索引的字段使用同样的索引到数组中,
  92. Theliteral*这里指它包含当前测试字段的值,
  93. 作为例子,考虑一个包含通讯地址和邮箱字段的form。如果通讯地址不为空则邮箱字段是必须的required。你能这样定义validwhen规则:
  94. <fieldproperty="emailAddress"depends="validwhen">
  95. <arg0key="userinfo.emailAddress.label"/>
  96. <var>
  97. <var-name>test</var-name>
  98. <var-value>((sendNewsletter==null)or(*this*!=null))</var-value>
  99. </var>
  100. </field>
  101. 上面定义的意思是:如果通讯地址是空或不空时这个字段时有效的。
  102. 这里有个稍微复杂的例子,它使用了索引字段。假定有一个表单,允许用户输入他们希望定购的部件号和数量。类orderLine的bean的一数组被用来在称为orderLines的一属性保持输入项。
  103. Ifyouwishedtoverifythateverylinewithpartnumberalsohadaquantityentered,youcoulddoitwith:
  104. 如果你希望校验订单中有数量输入得每一行,你可以这样:
  105. <field
  106. property="quantity"
  107. indexedListProperty="orderLines"
  108. depends="validwhen">
  109. <arg0key="orderform.quantity.label"/>
  110. <var>
  111. <var-name>test</var-name>
  112. <var-value>((orderLines[].partNumber==null)or(*this*!=null))</var-value>
  113. </var>
  114. </field>
  115. 这里的意思是:如果相应的partNumber字段是空,或这字段是不空的,则这字段是有效的。
  116. 最后一个例子,想象一表单,用户必须输入他们的以英寸为单位的高度,如果他们在高度在60英寸以下,则出一错误。(itisanerrortohavecheckedoffnbaPointGuardasacareer.)
  117. <fieldproperty="nbaPointGuard"depends="validwhen">
  118. <arg0key="careers.nbaPointGuard.label"/>
  119. <var>
  120. <var-name>test</var-name>
  121. <var-value>((heightInInches>=60)or(*this*==null))</var-value>
  122. </var>
  123. </field>
  124. 给程序员的简单说明:
  125. 所有的比较关系必须在parens封装。Allcomparisonsmustbeenclosedinparens.
  126. 只有两个itme时可以and或or链接。
  127. 如果比较的两item都可以转为整数,则使用numeric比较,否则使用字符串比较。
  128. 可插入验证器
  129. 验证是从validation.xml文件中加载的,默认的验证规则定义在validation.xml文件中,默认定义了required,mask,byte,short,int,long,float,double,date(没有本地支持),andanumericrange。
  130. "mask"方式依赖于默认值安装要求,那意味着"required"可以完成,在"'mask"将运行以前"required""mask"方式被默认包含进框架中了。任何字段如果不是"required"而且是空或有零长度将跳过其他验证。
  131. 如果使用了Javascript标签,客户端javascript在validator'sjavascript属性中查找值而且产生一个有验证form方法的对象,要得到更多的关于JavascriptValidator标签工作细节的详细的解释,参阅html标签API参考。
  132. "'mask'"方式让你用一正则表达式掩码验证字段,它使用jakarta的正规表达式包,所有的有效性规则存储在validator-rules.xml文件,使用的主类是org.apache.regexp.RE。
  133. validation.xml文件中的验证器配置范例:
  134. <validatorname="required"
  135. classname="org.apache.struts.validator.FieldChecks"
  136. method="validateRequired"
  137. methodParams="java.lang.Object,
  138. org.apache.commons.validator.ValidatorAction,
  139. org.apache.commons.validator.Field,
  140. org.apache.struts.action.ActionErrors,
  141. javax.servlet.http.HttpServletRequest"
  142. msg="errors.required">
  143. <validatorname="mask"
  144. classname="org.apache.struts.validator.FieldChecks"
  145. method="validateMask"
  146. methodParams="java.lang.Object,
  147. org.apache.commons.validator.ValidatorAction,
  148. org.apache.commons.validator.Field,
  149. org.apache.struts.action.ActionErrors,
  150. javax.servlet.http.HttpServletRequest"
  151. msg="errors.invalid">
  152. 定义可插入验证器
  153. 方法的参数是用逗号分隔的一些类名称列表,方法属性需要有一个符合上面的列表的签名。列表由以下组合而成:
  154. java.lang.Object–要验证的Bean。
  155. org.apache.commons.validator.ValidatorAction–当前ValidatorAction。
  156. org.apache.commons.validator.Field–要验证的字段
  157. org.apache.struts.action.ActionErrors–如果验证错误将加入ActionError的错误对象javax.servlet.http.HttpServletRequest–当前request对象。
  158. javax.servlet.ServletContext–应用的ServletContext。
  159. org.apache.commons.validator.Validator–当前的org.apache.commons.validator.Validator实例。
  160. java.util.Locale–当前用户的Locale。
  161. 多页面form
  162. 字段部分有一可选的页面属性,它可以被设为整数,页上字段的所有验证小于或等于服务器端验证的当前页,页上字段的所有验证小于或等于客户端页上所有字段的验证小于或等于服务器端验证的当前页验证的当前页。一个mutli-part表单需要定义页面属性:
  163. <html:hiddenproperty="page"value="1"/>。
  164. 比较两个字段
  165. 这是一个展示你怎样才能比较两个字段是否有一样的值的例子。比如“用户改变他们的口令“一般会有口令字段和一确认字段。
  166. <validatorname="twofields"
  167. classname="com.mysite.StrutsValidator"
  168. method="validateTwoFields"
  169. msg="errors.twofields"/>
  170. <fieldproperty="password"depends="required,twofields">
  171. <arg0key="typeForm.password.displayname"/>
  172. <var>
  173. <var-name>secondProperty</var-name>
  174. <var-value>password2</var-value>
  175. </var>
  176. </field>
  177. publicstaticbooleanvalidateTwoFields(
  178. Objectbean,ValidatorActionva,
  179. Fieldfield,ActionErrorserrors,HttpServletRequestrequest,
  180. ServletContextapplication){
  181. Stringvalue=ValidatorUtils.getValueAsString(bean,field.getProperty());
  182. StringsProperty2=field.getVarValue("secondProperty");
  183. Stringvalue2=ValidatorUtils.getValueAsString(bean,sProperty2);
  184. if(!GenericValidator.isBlankOrNull(value)){
  185. try{
  186. if(!value.equals(value2)){
  187. errors.add(field.getKey(),
  188. Resources.getActionError(application,request,va,field));
  189. returnfalse;
  190. }
  191. }catch(Exceptione){
  192. errors.add(field.getKey(),Resources.getActionError(application,request,va,field));
  193. returnfalse;
  194. }
  195. }
  196. }
  197. 已知的bug
  198. StrutsValidator依赖于CommonsValidator包,所以问题报告和增强需求可能在两个产品中列出。
  199. ·StrutsValidatorBugzillaReports
  200. ·CommonsValidatorBugzillaReports
  201. 变更和deprecations
  202. 新建的标记属性。
  203. <html:javascript>标记有新的属性定义.
  204. 使用commons-validator.jar中的DTD验证。
  205. 当前使用的验证XML文件是根据commons-validator.jar中的DTD。Struts不在为validator-rules.xmlandvalidator.xml.单独维护一个分离的DTD,另外,commons-validator现在维护一个统一的validator.dtd。修改所有validator.xml文件的DTD引用为
  206. <!DOCTYPEform-validationPUBLIC
  207. "-//ApacheSoftwareFoundation//DTDCommonsValidatorRulesConfiguration1.0//EN"
  208. "http://jakarta.apache.org/commons/dtds/validator_1_0.dtd">
  209. 空字段。
  210. 当前默认在所有得基础验证类型中忽略空白的字段,如果你要求一个字段必须输入,那末在你的应用的validator.xml文件相应的字段定义的depends属性中添加"required"
  211. 新建的范围RANGE方法.
  212. JavaScript和JAVA中都添加了intRange&floatRange方法。
  213. 有条件地REQUIRED字段.
  214. 最大的修改是添加了基于其她字段的值的有条件地require验证的能力。它允许你定义逻辑如:“只有X字段非空的时候Y字段为’male’才有效”,这是实现上述逻辑的推荐方法,这种方法在1.1版后的第一版将实现。在1.1版中添加的Requiredif验证规则,将在新版中去掉。不过,如果你正准备使用requiredif,这里有一个简短的教程。
  215. 让我们假定你有一个有3个字段的医药的信息表单,性别sex,怀孕测试pregnancyTest,测试结果testResult,如果性别为'f'or'F',则怀孕测试pregnancyTest是required,如果pregnancyTest不是空,测试结果testResult是required。
  216. 你的validation.xml文件的输入项应该是这样的:
  217. <formname="medicalStatusForm">
  218. <fieldproperty="pregnancyTest"depends="requiredif">
  219. <arg0key="medicalStatusForm.pregnancyTest.label"/>
  220. <var>
  221. <var-name>field[0]</var-name>
  222. <var-value>sex</var-value>
  223. </var>
  224. <var>
  225. <var-name>fieldTest[0]</var-name>
  226. <var-value>EQUAL</var-value>
  227. </var>
  228. <var>
  229. <var-name>fieldValue[0]</var-name>
  230. <var-value>F</var-value>
  231. </var>
  232. <var>
  233. <var-name>field[1]</var-name>
  234. <var-value>sex</var-value>
  235. </var>
  236. <var>
  237. <var-name>fieldTest[1]</var-name>
  238. <var-value>EQUAL</var-value>
  239. </var>
  240. <var>
  241. <var-name>fieldValue[1]</var-name>
  242. <var-value>f</var-value>
  243. </var>
  244. <var>
  245. <var-name>fieldJoin</var-name>
  246. <var-value>OR</var-value>
  247. </var>
  248. </field>
  249. <fieldproperty="testResult"depends="requiredif">
  250. <arg0key="medicalStatusForm.testResult.label"/>
  251. <var>
  252. <var-name>field[0]</var-name>
  253. <var-value>pregnancyTest</var-value>
  254. </var>
  255. <var>
  256. <var-name>fieldTest[0]</var-name>
  257. <var-value>NOTNULL</var-value>
  258. </var>
  259. </field>
  260. </form>
  261. 这里有一个使用索引的属性更复杂的例子,如果你的struts-config.xml有这下面:
  262. <form-beanname="dependentlistForm"
  263. type="org.apache.struts.webapp.validator.forms.ValidatorForm">
  264. <form-property
  265. name="dependents"
  266. type="org.apache.struts.webapp.validator.Dependent[]"size="10"/>
  267. <form-propertyname="insureDependents"type="java.lang.Boolean"initial="false"/>
  268. </form-bean>
  269. 这里dependentlistFormbean有lastName,firstName,dob,coverageType四个属性,你可以这样定义一验证规则:
  270. <formname="dependentlistForm">
  271. <field
  272. property="firstName"indexedListProperty="dependents"depends="requiredif">
  273. <arg0key="dependentlistForm.firstName.label"/>
  274. <var>
  275. <var-name>field[0]</var-name>
  276. <var-value>lastName</var-value>
  277. </var>
  278. <var>
  279. <var-name>fieldIndexed[0]</var-name>
  280. <var-value>true</var-value>
  281. </var>
  282. <var>
  283. <var-name>fieldTest[0]</var-name>
  284. <var-value>NOTNULL</var-value>
  285. </var>
  286. </field>
  287. <field
  288. property="dob"indexedListProperty="dependents"depends="requiredif,date">
  289. <arg0key="dependentlistForm.dob.label"/>
  290. <var>
  291. <var-name>field[0]</var-name>
  292. <var-value>lastName</var-value>
  293. </var>
  294. <var>
  295. <var-name>fieldIndexed[0]</var-name>
  296. <var-value>true</var-value>
  297. </var>
  298. <var>
  299. <var-name>fieldTest[0]</var-name>
  300. <var-value>NOTNULL</var-value>
  301. </var>
  302. </field>
  303. <field
  304. property="coverageType"indexedListProperty="dependents"depends="requiredif">
  305. <arg0key="dependentlistForm.coverageType.label"/>
  306. <var>
  307. <var-name>field[0]</var-name>
  308. <var-value>lastName</var-value>
  309. </var>
  310. <var>
  311. <var-name>fieldIndexed[0]</var-name>
  312. <var-value>true</var-value>
  313. </var>
  314. <var>
  315. <var-name>fieldTest[0]</var-name>
  316. <var-value>NOTNULL</var-value>
  317. </var>
  318. <var>
  319. <var-name>field[1]</var-name>
  320. <var-value>insureDependents</var-value>
  321. </var>
  322. <var>
  323. <var-name>fieldTest[1]</var-name>
  324. <var-value>EQUAL</var-value>
  325. </var>
  326. <var>
  327. <var-name>fieldValue[1]</var-name>
  328. <var-value>true</var-value>
  329. </var>
  330. <var>
  331. <var-name>fieldJoin</var-name>
  332. <var-value>AND</var-value>
  333. </var>
  334. </field>
  335. </form>
  336. 这里的意思是:
  337. 如果lastName字段是非空的,firstName字段required。因为字段Indexed为真,这它意味着lastName的indexed必须与firstName的索引的一样,dob同理,除非date不为空。
  338. 如果lastName用样索引时的值不空,而且非索引字段insureDependents为真,则coverageType是onlyrequire。
  339. 你可以对字段在[n]中使用任意数字,唯一的限制是他们必须都是AND或OR,你无法混合使用。
  340. Deprecation:
  341. uJavaScript和Java的range方法.
  342. uStrutsValidator&StrutsValidatorUtil类中的Deprecation方法
  343. 验证器api指南
  344. 一个简明的Struts验证器API指南可以帮助你开始。
  345. 验证器资源
  346. StrutsValidator:ValidatingTwoFieldsMatch作者MattRaible。(两个字段匹配验证)关于使用方法的文章。(范例部分为翻译此文内容)
  347. DynaFormsandtheValidator作者JamesTurnerandKevinBedell。StrutsKickstart的其中一章(动态form和验证器),可以自由下载PDF).
  348. Validatinguserinput作者DavidWinterfeldtandTedHusted。StrutsinAction的其中一章,可以自由下载(PDF)。
  349. 使用方法
  350. 作者:
  351. 丑陋&&Snowtears:经过2周的不懈努力,阅读了大量的资料,终于对Validator有了个初步的认识,整理了一下,浅浅的谈了谈写法,希望能有一定的帮助,其中肯定有许多说的不对不准确的地方,还请多指教real_herozx@163.net
  352. 王艺:
  353. 根据以上两位的文章正理而成
  354. 配置ruts-config.xml:
  355. 1、添加ApplicationResources配置文件。
  356. 如:
  357. <!--==========MessageResourcesDefinitions===========================-->
  358. <message-resourcesparameter="com.dc.sibss.om.struts.ApplicationResources"/>
  359. 其中com.sibss.om.struts.ApplicationResources"的部分是资源文件的路径,此文件的作用是提供错误信息的非编程定制化和多语言支持。如果我们使用中文平台操作系统,则默认情况下将首先查找ApplicationResource_zh_CN.properties文件,然后是ApplicationResources_zh.properties,如果前两个文件没有被找到则将查找ApplicationResources.properties文件。
  360. 为了能够在页面上显示错误提示信息,我们还需要将以下内容添加到ApplicationResources.properties文件的末尾:
  361. errors.required={0}isrequired.
  362. errors.minlength={0}cannotbelessthan{1}characters.
  363. errors.maxlength={0}cannotbegreaterthan{2}characters.
  364. errors.invalid={0}isinvalid.
  365. errors.byte={0}mustbeanbyte.
  366. errors.short={0}mustbeanshort.
  367. errors.integer={0}mustbeaninteger.
  368. errors.long={0}mustbeanlong.
  369. errors.float={0}mustbeanfloat.
  370. errors.double={0}mustbeandouble.
  371. errors.date={0}isnotadate.
  372. errors.range={0}isnotintherange{1}through{2}.
  373. errors.creditcard={0}isnotavalidcreditcardnumber.
  374. errors.email={0}isaninvalide-mailaddress.
  375. 以上仅是struts现在支持的错误类型的错误提示信息,如果你自定义了新类型的错误验证,则还需要在此加上你自己的内容。
  376. 以上内容中的{0}指的是错误提交的参数。比如:当你需要页面上的“用户名”不能为空时(也就是上面的errors.required),这个{0}就代表“用户名”,所以如果你没有填写用户名将抛出如下错误:
  377. 用户名isrequired.(你可以根据需要修改称中文)
  378. 我们可能已经注意到了,既然错误提示信息需要配置,那么上例中“用户名”系统是如何得到的呢?没错!也是通过修改此配置文件,内容如下:
  379. visitCust.error.name.required=<br>用户名
  380. 这样当“用户名”为空时,struts后台程序将联合以上两处定义显示错误信息。
  381. 另外,上面的“visitCust.error.name.required”是在Validation.xml配置验证内容时指定的。具体见以下介绍。
  382. 注意:一般情况下,你的系统只需要一个ApplicationResources文件,所以开发组的成员不要添加自己的resource文件。只有在你的项目分组开发时才需要使用多个ApplicationResources文件,但是,同时你的struts-config.xml文件也会有相同的数量对应。
  383. 2、在struts-config.xml文件中加入validator插件:
  384. 加入这个插件后你的应用就具备使用Validator的环境,如:
  385. <!--==========PlugInsConfiguration==================================-->
  386. <plug-inclassName="org.apache.struts.validator.ValidatorPlugIn">
  387. <set-propertyvalue="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"property="pathnames"/>
  388. </plug-in>
  389. 这里如果是想使用多个***.xml文件的话,value部分写法如下value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml,/WEB-INF/validation1.xml,/WEB-INF/validation2.xml"
  390. 在<action-mappings>里,定义需要验证的画面对应的Action的时候要加上validate="true"
  391. 四种使用方法
  392. 1、用Javascript在客户端进行验证
  393. 配置:在需要验证的JSP文件中写入
  394. <html:formaction="/XXX"οnsubmit="returnvalidateXXXX(this);">
  395. 这里的XXX是与要进行验证的forwardname,validateXXXX(this);里面的XXXX是需要进行验证的ActionForm名。
  396. <html:javascriptformName="mytestForm"/>
  397. 在validation.xml文件中写入验证代码就可以进行基本的验证了。这种方法是在客户端进行验证,客户端可以看到JAVASCRIPT部分的全代码。安全性不高
  398. 2、ValidatorForm的validate方法
  399. 1、validate()方法:使自己的ActionForm继承ValidatorForm类,在里面编写自己的方法:
  400. publicActionErrorsvalidate(ActionMappingmapping,HttpServletRequestrequest){
  401. ActionErrorserrors=newActionErrors();
  402. 。。。。。。
  403. if(mytext.equals("aaa")){
  404. //myexampleerrors.add("mytext",newActionError("mytext.error"));
  405. }
  406. 。。。。。。
  407. returnerrors;
  408. }
  409. 此时,如果写了这个方法,就会屏蔽掉在Validation.xml中定义的验证部分,换句话说就是系统运行时,Validation.xml里对应此ActionForm的定义的错误验证部分不实行,如果不写这个方法的话,系统运行时会进行Validation.xml里对应此ActionForm的定义的错误验证部分的操作。此类方法是在服务器端进行验证,验证部分代码客户端不可见。
  410. 2、创建你的ActionForm并让它继承org.apache.struts.validator.ValidatorForm类。创建你的Action实现,并和上面定义的ActionForm关联。这里需要注意的是,在定义此Action时一定将validate属性设置为true,并且在你定义的ActionForm中不要实现它的validate方法――这就意味着你将使用ValidatorForm的validate方法,这样才能保证你的错误验证正常进行。配置validation.xml文件。基本内容如下:
  411. <form-validation>
  412. <!--==========DefaultLanguageFormDefinitions=====================-->
  413. <formset>
  414. <formname="custGNewForm">需要验证页面上form的名字
  415. <fieldproperty="certifiCode"需要校验的属性
  416. depends="required,maxlength">校验内容
  417. <arg0key="prompt.certifiCode"/>ApplicationResource文件中对应
  418. <arg1key="${var:maxlength}"name="maxlength"resouce="false"/>
  419. <var>确定最长限制的长度
  420. <var-name>maxlength</var-name>
  421. <var-value>20</var-value>
  422. </var>
  423. </field>
  424. 注意:此处的arg0和arg1就代表了ApplicationResources文件中使用“{}”括起来的参数。比如:
  425. errors.range={0}isnotintherange{1}through{2}.
  426. 定义了三个参数,所以你这里也要定义<arg0>、<arg1>、<arg2>三个参数才能完整的显示错误信息。
  427. errors.maxlength={0}cannotbegreaterthan{2}characters.
  428. 定义了0、2两个参数,所以你就需要定义<arg0>和<arg2>两个参数。
  429. <fieldproperty="userName"
  430. depends="required,maxlength">
  431. <arg0key="prompt.userName"/>
  432. <arg2key="${var:maxlength}"name="maxlength"resouce="false"/>
  433. <var>
  434. <var-name>maxlength</var-name>
  435. <var-value>80</var-value>
  436. </var>
  437. </field>
  438. <fieldproperty="email"
  439. depends="email">
  440. <arg0key="prompt.email"/>
  441. </field>
  442. </form>
  443. <formname="custGNewCheckForm">
  444. <fieldproperty="certifiCode"
  445. depends="required">
  446. <arg0key="prompt.certifiCode"/>
  447. </field>
  448. </form>
  449. </formset>
  450. </form-validation>
  451. 在校验页面的<body>前添加如下内容:<html:errors/>
  452. 3、DynaValidatorForm
  453. 不需要再写对应的ActionForm,只需在struts-config.xml里把自己的ActionForm进行配置:
  454. <form-beanname="testForm"type="org.apache.struts.validator.DynaValidatorForm">
  455. <form-propertyname="mytext"type="java.lang.String"/>
  456. <form-propertyname="mytextarea"type="java.lang.String"/>
  457. <form-propertyname="mydatetext"type="java.lang.String"/>
  458. </form-bean>
  459. 在form-property里设置相应的项目,比如说mytext,mytextarea什么的,执行的时候会动态生成ActionForm,再在validation.xml里写入所希望的验证代码,就可以了。JSP文件里不需要写入任何东西,验证也是在服务器端进行,验证部分代码在JSP中不可见。
  460. 4、组合验证
  461. 如果使用动态验证DynaValidatorForm的话,不许编写自己的对应的ActionForm,相应的特殊验证会受到相当程度的限制。这个时候,需要将特殊验证部分写入对应的Action,
  462. if(mytext.equals("aaa")){//MyExample
  463. ActionErrorserrors=newActionErrors();
  464. errors.add("***",newActionError("***.error"));
  465. saveErrors(request,errors);
  466. return(mapping.findForward("false"));
  467. }
  468. 就可以实现特殊验证了。
  469. 实际上你的FORM还可以继承ValidatorActionForm和DynaValidatorActionForm,这两种与他们对应的ValidatorForm和DynaValidatorForm的唯一区别正如开篇就讲到的:在struts-config.xml中查找对应的FORM类时,前者根据ACTION的PATH值,而后者使用NAME值。
  470. 范例:
  471. Struts验证器:验证两个字段匹配
  472. 在使用指南中,有一节讲述怎样创建验证器来验证两个字段匹配,我用这个服务器端验证器(象例子中显示的那样)做口令,确定口令验证。这个已经可以正常工作了;但我还想用客户端的javascript验证器来试一试。我写了自己的程序来比较两个字段,但他们和推荐给你的那个不同(fromvalidator-rules.xml)。所以昨天,我补充了怎样添加JavaScript方法到validator-rules.xml。这里就是怎样配置的的整个过程(大部分在使用指南中已经包含了,保存JavaScript)。
  473. 怎样添加两个字段的验证器
  474. Step1:生成一个包含validateTwoFields方法的类。在我的代码重,我的类定义为ValidationUtil,他有下列方法:
  475. publicstaticbooleanvalidateTwoFields(
  476. Objectbean,
  477. ValidatorActionva,
  478. Fieldfield,
  479. ActionErrorserrors,
  480. HttpServletRequestrequest){
  481. Stringvalue=ValidatorUtil.getValueAsString(bean,field.getProperty());
  482. StringsProperty2=field.getVarValue("secondProperty");
  483. Stringvalue2=ValidatorUtil.getValueAsString(bean,sProperty2);
  484. if(!GenericValidator.isBlankOrNull(value)){
  485. try{
  486. if(!value.equals(value2)){
  487. errors.add(field.getKey(),
  488. Resources.getActionError(request,va,field));
  489. returnfalse;
  490. }
  491. }catch(Exceptione){
  492. errors.add(field.getKey(),
  493. Resources.getActionError(request,va,field));
  494. returnfalse;
  495. }
  496. }
  497. returntrue;
  498. }
  499. Step2:编辑validator-rules.xml,加入"twofields"规则。
  500. <validatorname="twofields"classname="org.appfuse.webapp.util.ValidationUtil"
  501. method="validateTwoFields"
  502. methodParams="java.lang.Object,
  503. org.apache.commons.validator.ValidatorAction,
  504. org.apache.commons.validator.Field,
  505. org.apache.struts.action.ActionErrors,
  506. javax.servlet.http.HttpServletRequest"
  507. depends="required"msg="errors.twofields">
  508. <javascript><![CDATA[
  509. functionvalidateTwoFields(form){
  510. varbValid=true;
  511. varfocusField=null;
  512. vari=0;
  513. varfields=newArray();
  514. oTwoFields=newtwofields();
  515. for(xinoTwoFields){
  516. varfield=form[oTwoFields[x][0]];
  517. varsecondField=form[oTwoFields[x][2]("secondProperty")];
  518. if(field.type=='text'||
  519. field.type=='textarea'||
  520. field.type=='select-one'||
  521. field.type=='radio'||
  522. field.type=='password'){
  523. varvalue;
  524. varsecondValue;
  525. //getfield'svalue
  526. if(field.type=="select-one"){
  527. varsi=field.selectedIndex;
  528. value=field.options[si].value;
  529. secondValue=secondField.options[si].value;
  530. }else{
  531. value=field.value;
  532. secondValue=secondField.value;
  533. }
  534. if(value!=secondValue){
  535. if(i==0){
  536. focusField=field;
  537. }
  538. fields[i++]=oTwoFields[x][1];
  539. bValid=false;
  540. }
  541. }
  542. }
  543. if(fields.length>0){
  544. focusField.focus();
  545. alert(fields.join('/n'));
  546. }
  547. returnbValid;
  548. }]]></javascript>
  549. </validator>
  550. Step3:在validation.xml中为你的表单配置验证:
  551. <fieldproperty="password"depends="required,twofields">
  552. <msgname="required"key="errors.required"/>
  553. <msgname="twofields"key="errors.twofields"/>
  554. <arg0key="userForm.password"/>
  555. <arg1key="userForm.confirmPassword"/>
  556. <var>
  557. <var-name>secondProperty</var-name>
  558. <var-value>confirmPassword</var-value>
  559. </var>
  560. </field>
  561. 这里errors.twofields的字段'{0}'必须与字段'{1}'的值相同。第三步的一个可选的工作就时使用XDoclet来生成validation.xml。requires(1)配置XDoclet(当然)和(2)在你的表单中添加添加一些@struts标签setPassword方法。
  562. /**
  563. *Returnsthepassword.
  564. *@returnString
  565. *
  566. *@struts.validatortype="required"msgkey="errors.required"
  567. *@struts.validatortype="twofields"msgkey="errors.twofields"
  568. *@struts.validator-argsarg1resource="userForm.password"
  569. *@struts.validator-argsarg1resource="userForm.confirmPassword"
  570. *@struts.validator-varname="secondProperty"value="confirmPassword"
  571. */
  572. publicStringsetPassword(){
  573. returnpassword;
  574. }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值