错误日志
错误分析
一 . 配置文件中 <context:property-placeholder location=“classpath:db.properties” /> 标签没有写
这个错误相信看完错误日志大家都能找的到, 就不多赘述了. 错误的原因就是, 如果没有加上面的标签, 那么下面配置文件代码中的
property标签中的value属性的值就仅仅是一个string类型的值, 而不是占位符. properties文件中的数据都是以key/value的形式存储的, 加上上面标签的话, 才会通过key去寻找properties文件中的value值, 注入进来.
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${jdbc.driverClassName}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
二 . 下面代码中多加入了 <property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
<!-- 批量代理对象生成 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 指定需要生成代理的接口所在的包名 -->
<property name="basePackage" value="com.daohewang.mapper"></property>
<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
</bean>
错误分析,: 这里需要跟到源码里面才能去解答了, 先给大家放一张spring 初始化bean的图片, 从图中我们可以看到, 从bean定义到bean实例过程中, 是要经过Bean后处理器(BeanFactoryPostProcessor)来操作的, 通过源码我们发现<context:property-placeholder ...>
和<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
这两个标签相对应的类都实现了BeanFactoryPostProcessor接口, 但是他们执行是有优先级之分的, <context:property-placeholder ...>
的优先级最低
所以这里如果加入这个标签的话, 会出现什么情况呢 ? 因为标签中的ref
属性的原因, 他会去找sqlSessionFactory, 但是sqlSessionFactory的创建需要注入dataSource, 很尴尬的是dataSource的创建需要加载<context:property-placeholder location="classpath:db.properties" />
标签, 但是此时他还未加载完成, 于是乎就出现了我们一开始谈起的那个错误. 这就是为什么你已经引入了properties文件, 还是报错的原因了.
解决办法有两个 :
- 方法一 : 去掉
<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
- 方法二 : 将方法一中的标签换成
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
即可