Terry.Li-彬

虚其心,可解天下之问;专其心,可治天下之学;静其心,可悟天下之理;恒其心,可成天下之业。

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  143 随笔 :: 344 文章 :: 130 评论 :: 0 Trackbacks
用登陆演示Model-Driven(模型驱动)、配置表单验证
本文主要在上一个视频(webwork初体验)的基本进行改动,所以在看本文之前,请先浏览上一个视频。
webworkAction根据Form的不同可分为二类:
一种是Field-Driven(字段驱动)Action;就是 Action用自己的字段来充当Form的角色,上一个视频给大家演示的例子就是采用了这种方式。本人感觉有点像struts中的动态Form
当然这只是我自己的一些看法。还有一种是Model-Driven(模型驱动)Action。它很像StrutsForm,但在strutsForm必须继承org.apache.struts.action.ActionForm;或是org.apache.struts.validator包下的几个Form.WebWork中有所不同,只要普通JavaBean就可以充当模型部分。只要我们在Action中实现com.opensymphony.xwork. ModelDriven接口就可以了,它有一个方法:Object getModel();,这个方法用于返回模型对象。
我们改动上个视频的LoginAction类。代码如下:
java 代码
  1. package com.lyx.web.action;   
  2. import com.lyx.bo.User;   
  3. import com.opensymphony.xwork.Action;   
  4. import com.opensymphony.xwork.ActionSupport;   
  5. import com.opensymphony.xwork.ModelDriven;   
  6. public class LoginAction implements Action,ModelDriven {   
  7. //注意这里的User一定要初始化   
  8.     private User user=new User();   
  9.   
  10.     public User getUser() {   
  11.         return user;   
  12.     }   
  13.     public String execute() throws Exception {   
  14.         if(user.getUserName().equals("lyx")){   
  15.             return this.SUCCESS;   
  16.         }else{   
  17.             return this.ERROR;   
  18.         }   
  19.     }   
  20.     public Object getModel() {   
  21.         // TODO Auto-generated method stub   
  22.         return user;   
  23.     }   
  24.   
  25. }  
红色字体部是我们后加部分。
然后我们就可以将index.jsp页面的代码修改如下:
<form action="login.action">
 
username:<input type="text" name="userName"/>
password:<input type="password" name="userPwd"/>
<input type="submit" value="login"/>
form>
也就是我们去掉了原有的表达式语言。
然后我们修改xwork.xml配置文件如下:
xml 代码
  1. <!--CTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.0//EN" "http://www.opensymphony.com/xwork/xwork-1.0.dtd"</sp-->>  
  2. <xwork>  
  3.     <include file="webwork-default.xml" />  
  4.     <package name="default" extends="webwork-default">  
  5.         <action name="login" class="com.lyx.web.action.LoginAction">  
  6.             <!--  登录成功后跳转到 /success.jsp 页面 -->  
  7.             <result name="success" type="dispatcher">  
  8.                 <param name="location">/success.jspparam>  
  9.             result>  
  10.             <!--  登录失败后跳转到 /error.jsp 页面 -->  
  11.             <result name="error" type="dispatcher">  
  12.                 <param name="location">/error.jspparam>  
  13.             result>  
  14.             <interceptor-ref name="model-driven"/>  
  15.             <interceptor-ref name="params"/>  
  16.         action>  
  17.     package>  
  18. xwork>  
也就是在原有的基础上加了一行模型驱动的拦截器。作用就是将模型对象保存到值堆栈中。
就样就OK了。这里要注意,model-driven拦截器要在params的上面。可以测试一下看看。
整过过程,非常像struts中,Action与ActionForm的关系。
通过测试,功能和以前的一样。很简单吧。就不在多述了。
第二个重点我们来配置一个表单的验证:
在 src 目录下新建 validators.xml 文件,文件内容如下:
xml 代码
  1. <validators>  
  2.     <validator name="required" class="com.opensymphony.xwork.validator.validators.RequiredFieldValidator"/>  
  3.     <validator name="requiredstring" class="com.opensymphony.xwork.validator.validators.RequiredStringValidator"/>  
  4.     <validator name="int" class="com.opensymphony.xwork.validator.validators.IntRangeFieldValidator"/>  
  5.     <validator name="date" class="com.opensymphony.xwork.validator.validators.DateRangeFieldValidator"/>  
  6.     <validator name="expression" class="com.opensymphony.xwork.validator.validators.ExpressionValidator"/>  
  7.     <validator name="fieldexpression" class="com.opensymphony.xwork.validator.validators.FieldExpressionValidator"/>  
  8.     <validator name="email" class="com.opensymphony.xwork.validator.validators.EmailValidator"/>  
  9.     <validator name="url" class="com.opensymphony.xwork.validator.validators.URLValidator"/>  
  10.     <validator name="visitor" class="com.opensymphony.xwork.validator.validators.VisitorFieldValidator"/>  
  11.     <validator name="conversion" class="com.opensymphony.xwork.validator.validators.ConversionErrorFieldValidator"/>  
  12.     <validator name="stringlength" class="com.opensymphony.xwork.validator.validators.StringLengthFieldValidator"/>  
  13. validators>  
这个文件可以在网上下得到。也可以在webwork的源码中得到。不是不想起了struts中有个valiator-rules.xml文件。这个文件在struts中是描述着验证的规则,里面有好多已经写好了的验证,我们可以很方便的调用。这里的这个文件功能和struts中的类似。
   要启动表单验证需要增加一个拦截器还有就是我们在strutsstruts-config.xml配置文件中Action的配置有个input属性,它是用来当验证失败时所在跳到的页,在这里如果登陆失败我们应该跳到index页,显示失败的原因,重新登陆。在webwork中我们也用input来描述这个功能。在一个result.
xwork.xml 文件进行修改增加<interceptor-ref name="validationWorkflowStack" />
修改后xwork.xml代码如下:
xml 代码
  1. <include file="webwork-default.xml" />  
  2.     <package name="default" extends="webwork-default">  
  3.         <action name="login" class="com.lyx.web.action.LoginAction">  
  4.             <!--  登录成功后跳转到 /success.jsp 页面 -->  
  5.             <result name="success" type="dispatcher">  
  6.                 <param name="location">/success.jspparam>  
  7.             result>  
  8.             <!--  登录失败后跳转到 /error.jsp 页面 -->  
  9.             <result name="error" type="dispatcher">  
  10.                 <param name="location">/error.jspparam>  
  11.             result>  
  12.             <result name="input" type="dispatcher">  
  13.                 <param name="location">/index.jspparam>  
  14.             result>  
  15.                
  16.             <interceptor-ref name="model-driven"/>  
  17.             <interceptor-ref name="params"/>  
  18.             <interceptor-ref name="validationWorkflowStack" />  
  19.         action>  
  20.     package>  
我们已经用到了success,他指成功所要跳到的页。Error是错误所要跳到的页。Input是指失败时所要返回来登陆的页。在webwork中还有几个。以后我们会看得到,用到的时候在详细讲解。
   建立验证规则
 
      LoginAction 进行验证规则的配置需要新建一个配置文件文件名起名是以Action 的名称开头以validation结尾,中间用-隔开.xml并保存到 LoginAction.java 文件所在的目录中
        
   代码如下: LoginAction-validation.xml
xml 代码
  1. <!--CTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0//EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.dtd"</sp-->>  
  2. <validators>  
  3.     <field name="userName">  
  4.         <field-validator type="requiredstring">  
  5.             <message>username is required!message>  
  6.         field-validator>  
  7.     field>  
  8.     <field name="userPwd">  
  9.         <field-validator type="requiredstring">  
  10.             <message> password is required!message>  
  11.         field-validator>  
  12.     field>  
  13. validators>  
这个文件很像struts中的validation.xml。功能和他是一样的。配置表单的验证。这里我们只验证也用户名和密码为必须填写。注意:这个name的属性一定要和User类中的对应。规则是和struts中一样的。对应才能有交的验证。
为了能显示验证的信息再次修改index页面如下:
<ww:form action="login.action" method="POST">
         username:   <ww:textfield label="Username" name="userName" required="true"/>
          password: <ww:password label="Password" name="userPwd" required="true"/>
            <ww:submit value="Submit"/>
     ww:form>
这几行很简单,从字面上就可以看出,就不在多述了。
基本代码就这些,测试一下,看看吧。
哦,没有验证,还忘了一步,回头看看
除了上述的配置外,我们的Action还要继承ActionSupport类,这个类存放着错误的信息,并能将错误的状态返回到页面
在改一下,试试
OK了。好用了。呵呵,刚是太急用了,忘了最关键的一步。大家在开发当中可以细心点啊。
因为,录这个视频是在公司,不能有声音讲解给大家听。请大家谅解。这段时间比较忙,过了这段时间,给大家录个有声音的。呵呵。
我的联系方式:
MSN;Lyx_2709@hotmail.com
Email:Lyx_happy@163.com
就到这里吧。希望大家能多提宝贵意见!
webwork模型驱动与表单验证.part1.rar
 描述:  第一部分视频
下载
 文件名:  webwork模型驱动与表单验证.part1.rar
 文件大小:  3 M
 下载过的:  文件被下载或查看 1277 次
webwork模型驱动与表单验证.part2.rar
 描述:  第二部分视频
下载
 文件名:  webwork模型驱动与表单验证.part2.rar
 文件大小:  3 M
 下载过的:  文件被下载或查看 1101 次
webworkfirst.rar
 描述:  程序源码
下载
 文件名:  webworkfirst.rar
 文件大小:  8 KB
 下载过的:  文件被下载或查看 350 次
posted on 2007-09-22 21:03 礼物 阅读(958) 评论(0)  编辑  收藏 所属分类: java