MVPHelper插件之混淆报错 ClassCastException: Object cannot be case to xxx

之前在android stduio里用mvphelper自动生成,最近要发包,加了混淆

打了个release包打开直接崩了,查看日志显示是获取的model为null。

以为是泛型的问题,但是加了过滤泛型

-keepattributes Signature 

最后想了很多都是不知道为什么

打log跟进类的转换

public static <T> T getT(Object o, int i) {
    try {
        return ((Class<T>) ((ParameterizedType) (o.getClass()
                .getGenericSuperclass())).getActualTypeArguments()[i])
                .newInstance();
    } catch (InstantiationException e) {
    } catch (IllegalAccessException e) {
    } catch (ClassCastException e) {
    }
    return null;
}

还是不行,但是网上有人不是混淆的原因,还是贴出来供大家参考自己的原因

最后猛然醒悟是混淆的原因把Model类给混淆了,所以object不能转换成model类型。

在混淆里

-keep class xxxx.model类

至此完美解决,多思多想,不要拘泥于一个小地方抓着不放

当你在MyBatis中遇到`ClassCastException: java.lang.String cannot be cast to java.util.Date`这类错误,通常是因为你在尝试将字符串转换为`Date`对象,但是传入的值并不是有效的日期格式。MyBatis默认会尝试将查询结果中的字符串解析为`Date`类型,如果数据库返回的数据不是`yyyy-MM-dd`、`yyyyMMdd`等标准日期格式,或者直接是一个非日期字符串,就会抛出这个异常。 解决这个问题,你可以做以下几个步骤: 1. **检查映射文件**:确认你的SQL语句是否正确地设置了`resultType`或`resultMap`属性为`java.util.Date`,并且对应的字段值可以被正确解析为日期。 2. **设置日期转换规则**:在MyBatis的配置文件`mybatis-config.xml`中,添加`<typeHandler>`元素,自定义一个处理`String`到`Date`转换的`TypeHandler`。 ```xml <typeHandler handler="com.example.YourCustomDateTypeHandler" javaType="java.util.Date" jdbcType="DATE"/> ``` 这里,你需要创建一个实现了`org.apache.ibatis.type.TypeHandler`接口的类,处理字符串到`Date`的转换。 3. **处理输入数据**:如果你是从用户输入或其他不可靠来源获取的日期字符串,可能需要先验证其格式,再进行转换。 4. **手动转换**:在业务逻辑中,你可以捕获这个异常,并显式地使用如`SimpleDateFormat`或`DateTimeFormatter`将字符串转换为`Date`。 **相关问题--:** 1. MyBatis如何处理非日期类型的查询结果? 2. 如何在MyBatis中自定义TypeHandler? 3. 如果日期格式不固定,如何在代码层面处理这种情况?
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值