由于TypeCoverter接口太复杂,所以OGNL 项目还提供了一个实现该接口的类 :DefaultTypeConverter.
如:com.DateTypeConvert.java:
public class DateConverter extends DefaultTypeConverter {//要记得继承此类
@Override public Object convertValue(Map context, Object value, Class toType) { //再重写convertValue方法 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd"); try { if(toType == Date.class){//当字符串向Date类型转换时,这时value的来源是从url或//者表单提交 String[] params = (String[]) value;// Request.getParameterValues() ,转换//为string数组是因为像复选框之类的组件可以提交的值是一个数组 return dateFormat.parse(params[0]);//解析成日期格式(注意:这里的日期一定要是util包下的日期) }else if(toType == String.class){//当Date转换成字符串时,这时value的来源是//action类,因此value不要强转为数组形式(注意:使用EL表达式向页面输出是该if不会被//执行,只有使用OGNL表达式向页面输出是才会进入此if语句) Date date = (Date) value; return dateFormat.format(date);//转换为字符串 } } catch (ParseException e) {} return null; } } 其中,context是类型转换环境的上下文,value是需要转换的参数,toType 是转换后的目标类型。
LoginAction.java:
import java.util.Date;
public class DateConvertAction { private Date date; public Date getDate() { return date; } public void setDate(Date date) { this.date = date; } public String execute() { System.out.println(date); return "ok"; } } 2.将该转换器注册在WEB应用中,这样 Struts 2 框架才能使用该类型的转换器。类型转换器的注册有 3种:
(1)注册局部类型转换器:仅仅对某个Action的属性起作用。
(2)注册全局类型的转换器:对所有Action 都有效。
(3)使用 JDK1.5 的注释来注册转换器。
局部类型转换器:
在需要生效的Action类的包下新建ActionName-conversion.properties该文件,其中 ActionName是需要转换生效的Action的类名,后面的-conversion固定。
内容: 待转换的action中的属性名=类型转换器的全类名。 注意:类型转换器是需要加包名,而且最后不能加标点符号
如:date=com.DateTypeConvert
全局类型转换器:
在WEB-INF/classes或者src目录下新建xwork-conversion.properties文件。文件名是固定的。【注】xwork表示全局
内容:待转换的类型 = 类型转换器的全类名
xwork-conversion.properties: java.util.Date=com.DateTypeConvert