由于mybatis-plus的3.5.6及以下版本存在SQL注入漏洞,所以把系统的mybatis-plus版本升级到了3.5.7,项目启动时,后台日志报错:nested exception is java.lang.NoClassDefFoundError::net.sf.jsqlparser.statement.select.SelectBody
详细分析:
1. 错误问题:
ClassNotFoundException是Java的常见异常,表示JVM在类路径中找不到指定的类。
NoClassDefFoundError 表示在编译时能找到类,但在运行时无法加载所需的类。
net.sf.jsqlparser.statement.select.SelectBody是JSqlParser库中的类,用于解析SQL的SELECT语句结构。
2. 可能原因:
- 依赖未正确引入:项目未添加JSqlParser的依赖,或依赖版本错误。
 - 依赖冲突:项目中存在多个不同版本的JSqlParser,导致类加载失败。
 - 打包问题:构建工具(如Maven/Gradle)未将依赖正确打包到最终产物中。
 
3. 解决方案:
检查maven依赖配置:
确保pom.xml(Maven)或build.gradle(Gradle)中包含正确的JSqlParser依赖。
经过排查升级的mybatis-plus-boot-starter包和系统中存在的分页jar包pagehelper-spring-boot-starter都存在jsqlparser包,两个版本不一致导致的系统报错,所以排除掉升级包中的对应jsqlparser即可。
方式一:排除冲突依赖
            
            
              xml
              
              
            
          
          <!-- 新升级的mybatis-plus -->
<dependency>
	<groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.7</version>
    <exclusions>
    	<exclusion>
    	 	<groupId>com.github.jsqlparser</groupId><!--排除掉冲突包 -->
    		<artifactId>jsqlparser</artifactId>
    	</exclusion>
    </exclusions> 
</dependency>
<!-- pagehelper分页包 -->
<dependency>
	<groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.4.1</version>
</dependency>
        方法二:调整依赖顺序
            
            
              xml
              
              
            
          
          <!-- PageHelper放在MyBatis Plus上面 -->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>最新版本</version>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>最新版本</version>
</dependency>
        4. 总结:
项目启动时报错nested exception is java.lang.NoClassDefFoundError:,除了未正确引入jar包外,也有可能是多个jar包之间存在不同版本的依赖冲突,本次报错就是依赖冲突导致的,所以在排除maven报错时需要额外注意不同版本可能引起的冲突。