struts学习进阶,第一部分讲到ActionForm和Action连用的情况,有些时候不需要使用ActionForm,这样更简洁方便。下面先来学习ForwardAction。
在struts中有个习惯,a.jsp要跳到b.jsp最好中间经过c.do。下面就来实现这个简单的跳转。要实现这个跳转其实只需要配置struts-config.xml文件
<action-mappings > <action path="/hello" type="org.apache.struts.actions.ForwardAction" parameter= "/hello.jsp"></action> </action-mappings>
path是要引用的地址,如本例在hello.html中使用一个超链接
<a href="hello.do">点这里</a>
parameter是链接到的地址。这个例子比较简单。接着学习下分发,DispatchAction。
为什么需要DispatchAction呢,为了减少Action的数量,这种Action会根据status的具体数值选择不同的执行方法,下面看一个具体例子。
new action,form。action继承自DispatchAction。
在表单上要添加一个hidden域
<html:form action="demo.do" method=""> 姓名:<html:text property="name"></html:text> <input type="hidden" name="status" value="update"/> <html:submit value="提交"></html:submit> </html:form>
struts-config.xml
<action attribute="demoForm" input="/form/demo.jsp" name="demoForm" path="/demo" scope="request" type="com.tanger.struts.action.DemoAction" parameter="status"> </action>
注意要在其中增加一个parameter属性,属性值设置的和hidden的name一致。再看action
public ActionForward insert(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { DemoForm demoForm = (DemoForm) form;// TODO Auto-generated method stub System.out.println("**insert name**--->"+demoForm.getName()); return null; } public ActionForward update(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { DemoForm demoForm = (DemoForm) form;// TODO Auto-generated method stub System.out.println("**update name**--->"+demoForm.getName()); return null; }
默认的方法名是execute,现在改成hidden域的值,这样可以调整hidden的value,执行的将是不同的方法。例如本例的status值为update,执行后的结果
**update name**--->test
即执行了update方法。
现在出现一个问题,就是ActionFrom过多的问题,每一个Action都对应一个ActionForm实在是太麻烦了,所以有了DynaValidatorForm。下面我们就将上面的例子改成动态的形式。
首先增加form-bean
<form-bean type="org.apache.struts.action.DynaActionForm" name="dynaForm"> <form-property name="name" type="java.lang.String"/> </form-bean>
由于表单上只有一个属性,所以这里只写一个,如果表单有多个这里就要写多个。接着修改以前的action
public ActionForward update(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { //DemoForm demoForm = (DemoForm) form;// TODO Auto-generated method stub DynaActionForm dynaForm=(DynaActionForm)(form); System.out.println("**update name**--->"+dynaForm.getString("name")); return null; }
改变以后获取属性的房还是不再是getName()而变成了getString(“name”)
最后能和demoForm达到相同的效果。但是又有一个问题产生了,如果不使用ActionForm那么如何进行验证操作呢?
struts提供了一个验证框架(validator-rules.xml),配置比较复杂,我们来做一个例子。
第一步:添加一个叫做validation.xml的验证规则(本例加入了required规则)
<?xml version="1.0"?> <!DOCTYPE form-validation PUBLIC "-//Apache Software Foundation//DTD Commons Validator Rules Configuration 1.1.3//EN" "http://jakarta.apache.org/commons/dtds/validator_1_1_3.dtd"> <form-validation> <formset> <form name="validateForm"> <field depends="required" property="name"> <arg resource="true" key="error.name"></arg> </field> </form> </formset> </form-validation>
其中error.name是作为参数传递到errors.required={0} is required.中的{0}。
第二步:所有错误信息要在资源文件中编写(error.name,error.required)
error.name=user name errors.required=<li>{0} is required.
第三步:配置struts-config.xml,在相应action中增加一个熟悉:validate="true"
<action attribute="validateForm" input="/dispatch.jsp" name="validateForm" path="/validate" scope="request" type="com.tanger.struts.action.ValidateAction" validate="true" parameter="status"> </action>
第四步:由于验证框架是struts的一个组件,所以要配置此组件。添加一个插件pluge new-->struts 1.2 pluge
<plug-in className="org.apache.struts.validator.ValidatorPlugIn"> <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" /> </plug-in>
这样就完成了整体配置,在jsp页面调用validate.do即可。<html:errors/>打印错误信息。
使用了验证框架以后,可以直接通过js进行错误的提示
去掉<html:errors/> 添加<html:javascript formName="validateForm"/> 会自动生成js函数
<!-- Begin var bCancel = false; function validateValidateForm(form) { if (bCancel) { return true; } else { var formValidationResult; formValidationResult = validateRequired(form); return (formValidationResult == 1); } } function validateForm_required () { this.a0 = new Array("name", "<li>user name is required.", new Function ("varName", " return this[varName];")); }
代码非常长,只截取关键部分。
我们在表单上调用该函数即可
<html:form action="validate.do" method="post" onsubmit="return validateValidateForm(this)"> 姓名:<html:text property="name"></html:text> <input type="hidden" name="status" value="update"/> <html:submit value="提交"></html:submit> </html:form>
这样就完成了js的调用,当name为空会弹出窗口提示。
附件是本例子的代码