Spring整合MVC和Mybatis框架

建立环境

建立Spring环境

  1. 创建maven工程,骨架选择webapp,导入依赖坐标

      <dependencies>
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>4.11</version>
          <scope>test</scope>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-aop</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-context</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.aspectj</groupId>
          <artifactId>aspectjweaver</artifactId>
          <version>1.9.2</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-context-support</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-web</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-orm</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-beans</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-core</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-test</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-webmvc</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-tx</artifactId>
          <version>${spring-version}</version>
        </dependency>
    
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>4.12</version>
          <scope>test</scope>
        </dependency>
    
        <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>8.0.13</version>
        </dependency>
    
        <dependency>
          <groupId>javax.servlet</groupId>
          <artifactId>servlet-api</artifactId>
          <version>2.5</version>
        </dependency>
    
        <dependency>
          <groupId>javax.servlet.jsp</groupId>
          <artifactId>jsp-api</artifactId>
          <version>2.2</version>
        </dependency>
    
        <dependency>
          <groupId>jstl</groupId>
          <artifactId>jstl</artifactId>
          <version>1.2</version>
        </dependency>
    
        <dependency>
          <groupId>log4j</groupId>
          <artifactId>log4j</artifactId>
          <version>1.2.16</version>
        </dependency>
    
        <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
          <version>1.7.20</version>
        </dependency>
    
        <dependency>
          <groupId>org.mybatis</groupId>
          <artifactId>mybatis-spring</artifactId>
          <version>1.2.2</version>
        </dependency>
    
        <dependency>
          <groupId>org.mybatis</groupId>
          <artifactId>mybatis</artifactId>
          <version>3.4.2</version>
        </dependency>
    
        <dependency>
          <groupId>c3p0</groupId>
          <artifactId>c3p0</artifactId>
          <version>0.9.1.2</version>
          <type>jar</type>
          <scope>compile</scope>
        </dependency>
      </dependencies>
    
  2. 在main文件夹下创建java文件夹和resources文件夹

  3. 在java文件夹下创建dao文件夹(持久层)和service文件夹(业务层),domain文件夹(bean),分别写上对应的类和接口

  4. resources文件夹下创建applicationContext.xml配置文件,拷入约束,并开启注解扫描

<!-- 相关约束 -->
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context.xsd
            http://www.springframework.org/schema/aop
            http://www.springframework.org/schema/aop/spring-aop.xsd
            http://www.springframework.org/schema/tx
            http://www.springframework.org/schema/tx/spring-tx.xsd">
 

开启注解扫描,处理service和dao,controller不需要spring去处理

<context:component-scan base-package="com.jingsheng">
        <!-- 配置哪些注释不扫描 -->
        <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
  1. 测试spring框架是否配置完毕,main下创建test文件进行测试

建立SpringMVC环境

  1. 配置web.xml

    <!-- 配置前端控制器 -->
    <servlet>
    <servlet-name>dispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>classpath:springmvc.xml</param-value>
        </init-param>
       	<load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
    	<servlet-name>dispatcherServlet</servlet-name>
    	<url-pattern>/</url-pattern>
    </servlet-mapping>
    
    <!-- 配置解决中文乱码的解析器 -->
    <filter>
        <filter-name>characterEncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
          <param-name>encoding</param-name>
          <param-value>UTF-8</param-value>
        </init-param>
    </filter>
      
    <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    
  2. 配置springmvc.xml

    <!-- 开启注解扫描,只扫描Controller注解 -->
    <context:component-scan base-package="com.jingsheng">
    	<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>
    
    <!-- 配置视图解析器 -->
    <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <property name="prefix" value="/WEB-INF/pages/"/>
            <property name="suffix" value=".jsp"/>
    </bean>
    
    <!-- 过滤静态资源 -->
    	<mvc:resources mapping="/css/**" location="/css/"/>
    	<mvc:resources mapping="/js/**" location="/js/"/>
    	<mvc:resources mapping="/images/**" location="/images/"/>
    
    <!--开启springmvc对注解的支持 -->
    <mvc:annotation-driven/>
    
    
    
  3. 创建一些文件夹及文件

    创建WEB-INF下的pages文件夹,并在其下创建list.jsp文件,用于返回时显示

  4. 进行测试


建立Mybatis环境

  1. 通过注解配置方法的sql语句(IAccountDao)
//查询所有用户
@Select(value = "select * from account")
List<Account> findAllAccount();
//添加用户
@Insert(value = "insert into account(name,money) values (#{name},#{money})")
void saveAccount(Account account);
  1. 创建Mybatis主配置文件SqlMapConfig.xml文件

    导入约束

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
            PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-config.dtd">
    

    导入jdbcConfig.properties文件

    <properties resource="SqlMapConfig.properties"></properties>
    

    配置环境,引入映射文件

    <environments default="mysql">
            <environment id="mysql">
                <transactionManager type="JDBC"></transactionManager>
                <dataSource type="POOLED">
                    <property name="driver" value="${jdbc.driver}"/>
                    <property name="url" value="${jdbc.url}"/>
                    <property name="username" value="${jdbc.username}"/>
                    <property name="password" value="${jdbc.password}"/>
                </dataSource>
            </environment>
    </environments>
     <mappers>
            
            <package name="com.jingsheng.dao"/>
            
     </mappers>
    
    1. 测试

整合

  1. Spring整合SpringMVC

    打开tomcat服务器,将ssm工程加载到服务器,运行后会发现,只会运行SpringMVC相关的内容,此时需要将Mybatis框架与SpringMVC进行整合,让Controller类能够调用业务层的对象进行数据的处理


思路分析:

为什么会发生此种现象?每次只会运行SpringMVC框架里面的内容,而不会运行Mybatis框架里面的内容

其实是因为web.xml没有配置spring的监听器,导致spring的配置文件无法加载

所以:

  1. 在web.xml问价下配置spring的监听器
<!--默认只加载WEB-INF目录下的applicationContext.xml配置文件,所以需要配置文件路径 -->
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 设置配置文件的路径 -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
</context-param>
  1. 此时在Controller类里面就可以调用业务层的对象,先定义对象,再采取自动注入的方式即可

Spring整合Mybatis框架

Spring要整合Mybatis框架,需要三步,目的是完成SqlMapConfig.xml文件应该完成的内容,并将SqlSessionFactory对象加入IOC容器

  1. 配置连接池
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="com.mysql.jdbc.Driver"/>
        <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/ssm?serverTimezone=GMT%2B8"/>
        <property name="user" value="root"/>
        <property name="password" value="xxxx"/>
</bean>
  1. 配置SqlSessionFactory工厂
<bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
	<property name="dataSource" ref="dataSource"/>
</bean>
  1. 配置AccountDao接口所在包
<bean id="mapperScan" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.xxxx.dao"/>
</bean>

此时,IOC已经帮我们完成了SqlMapConfig.xml文件应该完成的事情,所有删除SqlMapConfig.xml文件

  1. 在业务层调用持久层对象完成相关事务操作
@Autowired
private IAccountDao accountDao;
  1. 使用model将查询出的数据存储,然后使用jstl显示在jsp页面
 public String FindAllAccount(Model model){
        System.out.println("表现层:查询所有的账户.....");
        //调用service的方法
        List<Account> accounts = accountService.findAllAccount();

		//测试
      /*  for (Account account:
             accounts) {
            System.out.println(account);
        }*/
        model.addAttribute("accounts",accounts);

        return "list";

    }
  1. 在Controller类中通过accountService对象调用查询所有方法并通过jstl表达式显示在jsp文件中**

    [外链图片转存失败(img-BK358DOp-1564728083249)(C:\Users\user\AppData\Roaming\Typora\typora-user-images\1564713577749.png)]

注:如果jsp页面无法解析,需要在<%@ page… %>里面加上isELIgnored="false"

重新部署项目,启动后会报错:
项目报错信息
此时是因为spring,Mybatis-Spring,Mybatis版本对应不上

版本对应信息

调整版本坐标即可

此时又会报错…
项目报错信息...
这次是c3p0版本太低造成 …

再次导入c3p0的坐标

<dependency>
      <groupId>com.mchange</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.5.4</version>
      <type>jar</type>
      <scope>compile</scope>
 </dependency>

ojbk!

重新测试

[外链图片转存失败(img-yS7eqogQ-1564728083258)(C:\Users\user\AppData\Roaming\Typora\typora-user-images\1564725156758.png)]


接下来测试保存用户到数据库

由于是保存用户,所以需要配置事务(applicationContext.xml)

<!-- 配置Spring框架声明式事务管理 -->
<!-- 配置事物管理器-->
    <bean id="dataSourceTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <!-- 配置事务通知 -->
    <tx:advice id="txAdvice" transaction-manager="dataSourceTransactionManager">
        <tx:attributes>
            <tx:method name="find*" read-only="true" propagation="SUPPORTS"/>
            <tx:method name="*" read-only="false" propagation="REQUIRED" isolation="DEFAULT"/>
        </tx:attributes>
    </tx:advice>

    <!-- 配置AOP增强 -->
    <aop:config>
        <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.jingsheng.service.impl.*.*(..))"/>
    </aop:config>

接下来配置index.jsp文件,让其提交

<form action="account/save" method="post">

        姓名:<input type="text" name="name"/><br/>
        金额:<input type="text" name="money"/><br/>

        <input type="submit" value="提交">


</form>

紧接着配置Controller,处理前台传入的数据

@RequestMapping("save")
    public String SaveUser(Account account){


        accountService.saveAccount(account);

        System.out.println("保存成功!");

        return "success";
    }

测试

保存成功跳转图

数据库新增数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值