该帖已经被评为隐藏帖
|
|
---|---|
作者 | 正文 |
发表时间:2007-05-03
All Input Is Evil!
-Writing secure code 在写前几篇文章的时候,有些朋友建议我的写一篇关于表单数据校验的文章。 正如文章的开头所引用的《Writing Secure Code》的名言:“所有的输入都是罪恶的”,所以我们应该对所有的外部输入进行校验。而表单是应用程序最简单的入口,对其传进来的数据,我们必须进行校 验。 转换与校验(Conversion & Validation)其实上篇文章,我本来是打算写表单数据校验的内容,但是经过再三思考后,还是决定先写Struts 2.0转换器的内容。原因是我认为转换是校验的基础,只有在数据被正确地转换成其对应的类型后,我们才可以对其取值范围进行校验。看个例子相信大家可以更 清楚。现在我们就来改造一下《转换器(Converter)——Struts 2.0中的魔术师》的第一个例子。 首先,从Action开始,修改后的代码如下: package tutorial;
import java.util.Locale; import com.opensymphony.xwork2.ActionSupport; import com.opensymphony.xwork2.util.LocalizedTextUtil; public class HelloWorld extends ActionSupport { private String msg; private Locale loc = Locale.US; public String getMsg() { return msg; } public Locale getLoc() { return loc; } public void setLoc(Locale loc) { this .loc = loc; } @Override public void validate() { System.out.println( " Calling validate() " ); if ( ! (loc.equals(Locale.US) || loc.equals(Locale.CHINA))) { addFieldError( " loc " , getText( " validation.loc " )); } } public void validateExecute() { System.out.println( " Calling validateExecute() by reflection " ); } @Override public String execute() { System.out.println( " Calling execute() " ); // LocalizedTextUtil是Struts 2.0中国际化的工具类,<s:text>标志就是通过调用它实现国际化的 msg = LocalizedTextUtil.findDefaultText( " HelloWorld " , loc); return SUCCESS; } } 然后,修改Struts.xml中Action的定义指明输入地址: < action name ="HelloWorld" class ="tutorial.HelloWorld" >
< result > /HelloWorld.jsp </ result > < result name ="input" > /HelloWorld.jsp </ result > </ action > 接着,在HelloWorld.jsp中加入错误提示: <% @ page contentType = " text/html; charset=UTF-8 " %>
<% @taglib prefix = " s " uri = " /struts-tags " %> < html > < head > < title > Hello World </ title > </ head > < body > < div style ="color:red;" > < s:fielderror /> </ div > < s:form action ="HelloWorld" theme ="simple" > Locale: < s:textfield name ="loc" /> < s:submit /> </ s:form > < h2 >< s:property value ="msg" /></ h2 > </ body > </ html > 再修改LocaleConverter.java文件,将内容改为: package tutorial;
import java.util.Locale; import java.util.Map; import java.util.regex.Pattern; public class LocaleConverter extends ognl.DefaultTypeConverter { @Override public Object convertValue(Map context, Object value, Class toType) { if (toType == Locale. class ) { System.out.println( " Converting String to Locale " ); String locale = ((String[]) value)[ 0 ]; return new Locale(locale.substring( 0 , 2 ), locale.substring( 3 )); } else if (toType == String. class ) { System.out.println( " Converting Locale to String " ); Locale locale = (Locale) value; return locale.toString(); } return null ; } } 之后,修改国际化资源文件,内容为: HelloWorld = 你好,世界!
globalMessages_zh_CN.properties invalid.fieldvalue.loc = Locale必须为\ " xx_XX\ " 的格式 validation.loc = 区域必须为中国或美国 HelloWorld = Hello World!
globalMessages_en_US.properties
invalid.fieldvalue.loc = Locale must like \ " xx_XX\ " validation.loc = Locale must be China or USA 发布运行应用程序,在浏览器中键入http://localhost:8080/Struts2_Validation/HelloWorld.action,在Locale中输入zh_CN,按“Submit”提交,效果如上篇文章所示。而在服务器控制台有如下输出: Converting String to Locale...
Calling validateExecute() by reflection... Calling validate()... Calling execute()... Converting Locale to String... 上述的输出说明了Struts 2.0的数据校验工作方式,它需要经过下面几个步骤:
不喜欢看文字的朋友,可以参考下面的图1。 看到这里可能大家会疑问:“这么多地方可以校验表单数据,到底我应该在那里做呢?”有选择是好事,但抉择的过程往往是痛苦的,往往让人不知所措。如果大家参照以下几点建议,相信会比较容易地做出正确的抉择。
在运行上面的例子时,在Locale中输入zh并提交时出现图2所示页面。 在Locale中输入de_DE时,出现如图3所示页面。 使用Struts 2.0的校验框架上一节的内容都是关于如何编程实现校验,这部分工作大都是单调的重复。更多情况下,我们使用Struts 2.0的校验框架,通过配置实现一些常见的校验。 我学习编程有个习惯——喜欢先看输出结果,再看代码实现。这样学的好处是先看结果可以刺激学习的激情,也可以在看代码前自已思考一下如何实现,然后带着问题去看代码,那就清晰多了。因此下面我们先来做演示。 首先,在tutorial包下新建ValidationAction.java,代码如下: package tutorial;
import com.opensymphony.xwork2.ActionSupport; public class ValidationAction extends ActionSupport { private String reqiuredString; public String getReqiuredString() { return reqiuredString; } public void setReqiuredString(String reqiuredString) { this .reqiuredString = reqiuredString; } @Override public String execute() { return SUCCESS; } } 然后,配置上述所建的Ation,代码片段如下: < action name ="ValidationAction" class ="tutorial.ValidationAction" >
< result > /Output.jsp </ result > < result name ="input" > /Input.jsp </ result > </ action > 接着,创建Input.jsp和Output.jsp,内容分别如下: <% @ page contentType = " text/html; charset=UTF-8 " %>
<% @taglib prefix = " s " uri = " /struts-tags " %> < html 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
浏览 2022 次