java Spring和mybatis整合时,junit测试时报的错。搞了二个小时了,还没解决。求助

这是我的Junit的代码:
@Test
public void test1(){
SqlSessionFactoryBuilder ssfb= new SqlSessionFactoryBuilder();

     System.out.println("ssfb:"+ssfb);

    InputStream is= Test1.class.getClassLoader().getResourceAsStream("spring-mybatis.xml");
    System.out.println("is:"+is);
            SqlSessionFactory ssf = ssfb.build(is);
            System.out.println("dd");

     session = ssf.openSession();
     dao = session.getMapper(Aoo2Dao.class);

     Aoo2 a2 = new Aoo2();

     a2.setId(19);
     a2.setName("钻石王老五");
     a2.setAge(37);
     a2.setPhone("13500990888");
     dao.add(a2);
     //提交事务
       session.commit();
       session.close();
 }
 ,运行报错。错误是PersistenceException,文档根元素beans必须匹配
 DOCTYPE根null。求解答。

 我的spring-mybatis.xml文件是:
 <?xml version="1.0" encoding="UTF-8"?>

<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop" 
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:util="http://www.springframework.org/schema/util"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xsi:schemaLocation="  
   http://www.springframework.org/schema/beans   
   http://www.springframework.org/schema/beans/spring-beans-4.3.xsd  
   http://www.springframework.org/schema/mvc   
   http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd   
   http://www.springframework.org/schema/tx   
   http://www.springframework.org/schema/tx/spring-tx-4.3.xsd   
   http://www.springframework.org/schema/aop 
   http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
   http://www.springframework.org/schema/util 
   http://www.springframework.org/schema/util/spring-util-4.3.xsd
   http://www.springframework.org/schema/data/jpa 
   http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd">


    <util:properties 
    id="db" location="classpath:db.properties"   />

    <!-- 配置数据库连接池 -->
    <bean id="ds" 
    class="org.apache.commons.dbcp.BasicDataSource"
    destroy-method="close">
        <property name="driverClassName"  
        value="#{db.driver}"/>
        <property name="url"  
        value="#{db.url}"/>
        <property name="username"   
        value="#{db.user}"/>
        <property name="password"  
        value="#{db.password}"/>
    </bean>

    <!-- 配置SqlSessionFactoryBean -->
    <!-- 
        该bean的作用是用来代替MyBatis配置文件
     -->
     <bean  
     class="org.mybatis.spring.SqlSessionFactoryBean">
         <!-- 指定连接池 -->
         <property name="dataSource" ref="ds"/>
         <!-- 指定映射文件位置 -->
         <property name="mapperLocations"
         value="classpath:entity/*.xml"/>
     </bean>
     <!-- 配置MapperScannerConfigurer -->
     <!-- 
         该bean会扫描指定包及其子包下面的所有的Mapper
         映射器(接口),然后生成符合该接口要求的对象
         (通过调用SqlSession的getMapper方法),接下来,
         会将这些对象(即Mapper映射器的实现对象)添加到
         Spring容器里面(默认的id是首字母小写之后的接口名)。
      -->
      <bean 
      class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <!-- 指定要扫描的包 -->
            <property name="basePackage" value="dao"/>
            <!-- 指定只扫描带有该注解的接口 -->
         <property name="annotationClass" value="annotations.MyBatisRepository"/> 

      </bean>

3个回答

有可能是你的beans重复了,你把Mapper.xml贴出来看看,最好带上行号。

qq_36142320
HermioneZhou 我已经解决了。哦yeah。原因是我写的junit测试的代码还是用单独的Mybatis环境下的SqlSession的getMapper()方法来获得dao对象,这已经是spring和mybatis整合环境下的,所以我用ApplicationConext接口的getBean()方法来获得dao对象就好了。我粗心了。
6 个月之前 回复

是不是spring-mybatis.xml的结尾没有写

</beans>
qq_36142320
HermioneZhou 万分感谢,你抽出宝贵的时间来帮忙解决我的问题。
6 个月之前 回复
qq_36142320
HermioneZhou 写了,我刚才自己解决了。谢谢你!
6 个月之前 回复

可能是你的 Aoo2Dao.class 对应的 xml 配置文件的头忘记加了
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
这个要加在 <?xml version="1.0" encoding="UTF-8"?> 和 之间 ;

qq_36142320
HermioneZhou 没有,我加了的。我刚才自己解决了。小哥。
6 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!