SSM 整合时出现的一些错误以及解决方法

在整合SSM时,由于配置较多,很容易出错,有时候一时半会也找不到错误,今天就用这篇文章记录下本人遇到的错误以及解决方法。

Mybaits 部分

Mybatis 部分是很容易出错的部分,原因是其配置较多,特别是一些细节的地方,千万要细心。

数据库连接错误

Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is java.sql.SQLException: An attempt by a client to checkout a Connection has timed out.

原因:数据库配置文件 database.properties 有错
正确的格式应如下:

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?useSSL=false&useUnicode=true&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=123456

注意这里的 useSSL要为 false ,一开始写的是 true 就报上述错误,检查了 mybatis 配置文件以及 sql 发现都没错,最后找了很久才发现原来是数据库配置文件的问题

资源导出问题

在 Mybatis 部分,Mapper.xml 要与 Mapper 接口的包名一致,如果将 Mapper.xml 放在 java 目录下,Maven 不会导出该资源,需在 pom.xml 中添加导出 xml 资源的代码才行。

    <build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>
    </build>

Mapper 中方法找不到

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.xie.dao.BooksMapper.queryBookById

原因:Mapper 有问题,检查 Mapper 扫描是否有出错,Mapper 是否绑定好 java 接口,同时还有标签名要与方法名一致!(本人就在这里错误,原因是 ID 的拼写大小写出错!)

Spring MVC 部分

启动 Tomcat 后访问首页出错

原因:资源没有正确添加,检查编译后的文件的WEB-INF目录下是否有 lib 目录,如果没有就是错的
解决方法:在 Project Structure 中,进入到 Artifacts 中,添加 lib 目录并将 Maven 依赖导入
注意:lib 目录必须在 WEB-INF 目录下!!!

在这里插入图片描述

最后

报错时要静下心来,仔细分析可能出现问题的地方,最好用 junit 进行测试,就写点测试代码也不麻烦,当然,学会搜索解决方案也十分重要,解决 bug 也是一个成长的过程!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
出现"this.****Mapper is null"的问题通常是由于Mapper对象没有被正确注入导致的。根据您提供的信息,您的SSM项目使用了MyBatis进行数据库操作,而出现空指针异常的问题可能与Mapper对象的注入有关。 在SSM项目,Mapper对象通常是通过Spring的依赖注入功能进行注入的。请确保您的Mapper接口已经正确配置为Spring的bean,并且在相应的地方进行了注入。对于您提供的例子,RoleMapper和PermissionMapper接口应该被正确配置,并且在需要使用它们的地方进行了注入。 请检查以下几个方面来解决这个问题: 1. 确保在Spring的配置文件正确配置了Mapper接口的扫描路径,使其能够被Spring扫描到并注册为bean。 2. 确保Mapper接口上添加了`@Mapper`注解,以告诉MyBatis框架将其作为Mapper接口进行处理。 3. 确保在需要使用Mapper对象的地方,使用`@Autowired`注解将其注入。 例如,假设您的Mapper接口位于`com.wzh.mapper`包下,您可以在Spring的配置文件添加以下配置: ```xml <!-- 扫描Mapper接口所在的包 --> <mybatis:scan base-package="com.wzh.mapper" /> ``` 然后,在需要使用Mapper对象的地方,使用`@Autowired`注解进行注入,例如在Service类: ```java @Autowired private RoleMapper roleMapper; @Autowired private PermissionMapper permissionMapper; ``` 这样就可以确保Mapper对象被正确注入,避免出现空指针异常。 另外,还需要确保数据库连接配置、MyBatis配置以及Mapper映射文件的配置都正确无误。如果以上步骤都没有解决您的问题,可以进一步检查日志文件,查看是否有其他错误或异常信息提供更多线索。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SSM项目整合测试出现this.****Mapper is null的问题](https://blog.csdn.net/weixin_51337996/article/details/126958819)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SSM整合shiro](https://blog.csdn.net/weixin_68509156/article/details/126186110)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值