struts2的自定义类型转换和异常处理

 在web层中,我们使用beanutils直接将表单的数据封装到JavaBean中。而在struts2中,action得到请求也能直接封装到Javabean中。struts2中提供了大量的类型转换器,用来完成数据类型转换问题。包含以下类型:

        booleanBoolean
        char和 Character
        int 和 Integer
        longLong
        float 和 Float
        doubleDouble
        Date 可以接收 yyyy-MM-dd格式字符串
        数组  可以将多个同名参数,转换到数组中
        集合  支持将数据保存到 List 或者 Map 集合

在struts2中的类型转换器的接口是:com.opensymphony.xwork2.conversion.TypeConverter

1. 为何要自定义类型转换?
 因为在struts2提供的类型转换在我们实际需求开发中,会存在不能满足开发需求的情况,比如将字符串2017/6/27装换成时间数据Data2017年6月27日上就会发生异常,因为struts2并没有这种类型转换器,而为了解决我们的需求问题,我们必须自己写一个自定义类型转换器。

2. 自定义类型转换器步骤
<1>创建一个自定义类型转换器。
创建自定义类型转换器有三种方法:
 (1)实现TypeConverter接口

//重写这个方法。但是由于参数有六个,参数过多,不建议使用。
public Object convertValue(Map<String, Object> context, Object target, Member member, String propertyName, Object value, Class toType);

(2)继承DefaultConverter类

//重写的方法参数并没有那么多
public Object convertValue(Map<String, Object> context, Object value, Class toType) {
    return convertValue(value, toType);
}

(3)继承DefaultTypeConverter类的一个子类:StrutsTypeConverter

//建议使用这个方法,因为在这个类中,将从页面传递的数据怎么封装以及action中的数据怎样在页面上显示做了分离。
//参数value:表单要转换的值
//参数toClass:要转换的类型
public abstract Object convertFromString(Map context, String[] values, Class toClass);
public abstract String convertToString(Map context, Object o);

<2>重写接口中的方法,实现类型转换操作。
<3>注册类型转换器。
怎样注册一个自定义类型转换器?
 (1) 局部–针对action
配置文件所在位置以及名称:在Action类所在包,创建Action类名-conversion.properties
配置文件书写格式:属性名称=类型转换器的全类名

 (2) 局部–针对model
配置文件所在位置以及名称:在model类所在包,创建model类名-conversion.properties
配置文件书写格式:属性名称=类型转换器的全类名
 (3) 全局
配置文件所在位置以及名称:在src下创建一个xwork-conversion.properties
配置文件书写格式:要转换的类型全名=类型转换器的全类名

3. 类型转换器异常及其处理
 对于struts2中的类型转换器,如果表单数据提交时,将数据想model封装,出现的问题,就会报错,例如:No result defined for action cn.itcast.action.RegistAction and result input。
将异常信息翻译过来的意思为:在RegistAction的配置中没有配置input结果视图。

//如果配置以下信息,那么出现类型转换问题,就会跳转到指定的视图。
<action name="regist" class="cn.itcast.action.RegistAction">
        <result name="input">/success.jsp</result>          
</action>

那么为什么会向input视图跳转呢?
 原因是struts2中的拦截器(intercepter)。

//用于记录类型转换问题
<interceptor name="conversionError" 
class="org.apache.struts2.interceptor.StrutsConversionErrorInterceptor"/>

// 用于得到问题,向input视图跳转。
<interceptor name="workflow" class="com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor"/>

因为struts2中引入了默认的拦截器栈。在这个默认的拦截器栈中,有一个拦截器是conversionError,它的作用是当类型转换出现错误的时候,会向action中存储错误信息。然而在栈尾还有一个拦截器是workflow,它的作用是如果前面的拦截器发现了问题,并将问题存储到了action中,或者抛出了异常,那么workflow拦截器就会直接跳转的到input视图。

4. 关于错误信息展示
通过分析拦截器作用,得知当类型转换出错时,自动跳转input视图 ,在input视图页面中 显示错误信息。
* 在Action所在包中,创建 ActionName.properties,在局部资源文件中配置提示信息 : invalid.fieldvalue.属性名= 错误信息

如果是自定义类型转换器,出现类型转换问题,要跳转到input视图,在类型转换器中,必须抛出异常才可以。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值