问题:
想问一下,对于validate方法中验证出现错误,手动的添加字段级别错误或者动作级别错误,这些错误信息保存在哪里了,除了struts标签取出,还有别的方法没? 假如对于INPUT ,我重定向到别的页面那么错误信息能提取出来吗?为什么?
解答:
添加的错误信息都在当前的Action对象上吧
在validate一般都是用this.addFieldError()这个方法吗,thiis就是当前Action对象
除了用标签,还可以用EL表达式等取,比如:${errors['错误字段名']},这个可以指定取出哪个错误消息
最后对于INPUT,在别的页面也能取出来,这个可能是Struts2的一种机制吧,后台Action对象传给前台页面
希望对你有帮助
我的补充:
补充一下,下面是我做的一个例子:
这个是修改密码的页面对应的action的validateChangePassword()方法:
this.addFieldError("pwd.oldpwd", "请输入登录时的密码");
如果在<result name="input">中配置的不是修改密码的那个页面,出错的信息也能显示出来。
struts2中action的validate()方法的验证机制:
举例说明:
在访问Action的 login方法时,struts2会首先查找是否存在 validateLogin() 方法,
如果存在,则先执行 validateLogin() 方法。
如果在 validateLogin()方法中,遇到 this.addFieldError()方法,
则自动返回一个名称为"input"的字符串,转向struts.xml中配置的对应的action的
<result name="input"> 指定的页面中去。
struts2中访问action的机制:(当package目录只为2级时)
访问Acton时,Struts2首先会根据 访问的URL,去找对应的Acton
如果找不到,则会到根目录下去找。
如果还找不到,则回报错。
注意:如果某个Action的访问地址是在一个包下面(这个包不是默认的包),则只能通过指定的URL访问到这个Action。
------------------------
Action名搜索路径
1.获得请求路径的URI,例如url是:http://server/struts2/path1/path2/path3/test.action
2.首先寻找namespace为/path1/path2/path3的package,如果不存在这个package则执行步骤3;如果存在这个package,则在这个package中寻找名字为test的action,当在该package下寻找不到action 时就会直接跑到默认namaspace的package里面去寻找action(默认的命名空间为空字符串“” ) ,如果在默认namaspace的package里面还寻找不到该action,页面提示找不到action
3.寻找namespace为/path1/path2的package,如果不存在这个package,则转至步骤4;如果存在这个package,则在这个package中寻找名字为test的action,当在该package中寻找不到action 时就会直接跑到默认namaspace的package里面去找名字为test的action ,在默认namaspace的package里面还寻找不到该action,页面提示找不到action
4.寻找namespace为/path1的package,如果不存在这个package则执行步骤5;如果存在这个package,则在这个package中寻找名字为test的action,当在该package中寻找不到action 时就会直接跑到默认namaspace的package里面去找名字为test的action ,在默认namaspace的package里面还寻找不到该action,页面提示找不到action
5.寻找namespace为/的package,如果存在这个package,则在这个package中寻找名字为test的action,当在package中寻找不到action或者不存在这个package时,都会去默认namaspace的package里面寻找action,如果还是找不到,页面提示找不到action。
3.Action配置中,个配置项的默认值
1.如果没有指定Action的class,默认值为ActionSupport。
2.如果没有指定Action的method属性,默认值为execute()方法。
3.如果没有指定result的name属性,默认值为“success“
引自:
http://zhidao.baidu.com/question/441168510.html
http://gongqi.iteye.com/blog/749920
http://johnjobe.iteye.com/blog/1573301
--