本项目在引入devtools前的环境介绍:
springboot 2.1.3.RELEASE、mybatis-plus 3.1.1、shiro-spring1.4.0、shiro-redis3.2.2、thymeleaf-extras-shiro2.0.0
前端用的是 spring-boot-starter-thymeleaf
在没有引入devtoos前,环境启动正常,运行没有异常发生。
引入后,启动正常,运行时错误:java.lang.ClassCastException:....User cannot be cast to cn....User,一个User对象不能转换成另一个User,很诡异。
网上找原因,发现大家给出了统一的问题原因:
项目启动时加载项目中的类使用的加载器都是
org.springframework.boot.devtools.restart.classloader.RestartClassLoader
而从shiro session 取出来的对象(从redis中取出经过反序列化)的类加载器都是
sun.misc.Launcher.AppClassLoader
很明显会导致类型转换异常,原来Spring的dev-tools为了实现重新装载class自己实现了一个类加载器,来加载项目中会改变的类,方便重启时将新改动的内容更新进来。
然后解决方案如下 :
方案一、不使用spring-boot-devtools(这怎么能行,开发很不方便呀!!!!!)
方案二、在resources目录下面创建META-INF文件夹,然后创建spring-devtools.properties(spring-devtools敲黑板,注意此处文件名称,写成其他类似spring-boot-devtools的名字不生效。)
spring-devtools.properties 文件内容如下:
restart.include.mybatis=/mybatis-[\\w-\\.]+jar
restart.include.shiro=/shiro-[\\w-\\.]+jar
restart.include.xmlnsshiro=/thymeleaf-extras-shiro-[\\w-\\.]+jar
restart.include.mybatis=/mybatis-[\\w-\\.]+jar(红色key随意,不重复即可,value的值根据自己实际项目情况配置)