SSM三大框架的整合

好好學習,每天向上php

文本已收錄至個人Github倉庫DayDayUP:github.com/RobodLee/DayDayUP,歡迎Star,更多文章請前往:目錄導航html

在Java後端開發領域,Spring+SpringMVC+MyBatis三大框架的使用尤其頻繁,不少朋友學了這三個框架殊不知道怎麼整合起來,本文將帶着你們一步步的實現三大框架的整合。我也是初學者,寫做本文的目的一方面是想讓你們少走點彎路,還有一方面是爲了加深本身對於這三大框架的理解。整合的思路是以Spring框架爲核心去整合SpringMVC和MyBatis框架。首先咱們須要建立一個項目而且準備好測試用的數據庫。前端

一.準備工做

怎麼建立Maven工程我相信你們都會,我就再也不贅述了,不會的朋友請自行百度。 我建立了一個叫SSMTest的項目,而後使用MySQL建立了一個叫ssmtest的數據庫而且建立了一張user表,爲了節省你們的時間,我將sql語句粘貼在這裏:java

create database ssmtest;
use ssmtest;
create table user(
id int primary key auto_increment,
name varchar(20),
age int
);
複製代碼

而後就須要準備好所需的jar包和配置文件,我將個人整個pom文件的內容都粘貼在這裏,你們自行參考。mysql

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>com.playman</groupId>
  <artifactId>SSMTest</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>war</packaging>

  <name>SSM Maven Webapp</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
    <spring.version>5.0.2.RELEASE</spring.version>
    <slf4j.version>1.6.6</slf4j.version>
    <log4j.version>1.2.12</log4j.version>
    <mysql.version>5.1.6</mysql.version>
    <mybatis.version>3.4.5</mybatis.version>
  </properties>

  <dependencies>
    <!-- spring -->
    <dependency>
      <groupId>org.aspectj</groupId>
      <artifactId>aspectjweaver</artifactId>
      <version>1.6.8</version>
    </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.springframework</groupId>
      <artifactId>spring-web</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-test</artifactId>
      <version>${spring.version}</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>${spring.version}</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>${spring.version}</version>
    </dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>compile</scope>
    </dependency>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>${mysql.version}</version>
    </dependency>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>servlet-api</artifactId>
      <version>2.5</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>javax.servlet.jsp</groupId>
      <artifactId>jsp-api</artifactId>
      <version>2.0</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>jstl</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
    </dependency>
    <!-- log start -->
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>${log4j.version}</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>${slf4j.version}</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>${slf4j.version}</version>
    </dependency>
    <!-- log end -->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>${mybatis.version}</version>
    </dependency>

    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.3.0</version>
    </dependency>
    <dependency>
      <groupId>c3p0</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.1.2</version>
      <type>jar</type>
      <scope>compile</scope>
    </dependency>
  </dependencies>

  <build>
    <finalName>SSMTest</finalName>
    <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
      <plugins>
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-war-plugin</artifactId>
          <version>3.2.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
        <!--jdk編譯插件-->
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <configuration>
            <source>1.8</source>
            <target>1.8</target>
            <encoding>utf-8</encoding>
          </configuration>
        </plugin>
        <!--tomcat插件-->
        <plugin>
          <groupId>org.apache.tomcat.maven</groupId>
          <!-- tomcat7的插件, 不一樣tomcat版本這個也不同 -->
          <artifactId>tomcat7-maven-plugin</artifactId>
          <version>2.1</version>
          <configuration>
            <!-- 經過maven tomcat7:run運行項目時,訪問項目的端口號 -->
            <port>8080</port>
            <!-- 項目訪問路徑 本例:localhost:9090, 若是配置的aa, 則訪問路徑爲localhost:9090/aa-->
            <path>/ssmtest</path>
            <!-- 解決中文亂碼問題 -->
            <uriEncoding>UTF-8</uriEncoding>
          </configuration>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>
複製代碼

如今就能夠將一些所須要的目錄以及文件先建立好:git

目錄結構

OK!準備工做完成了,咱們就能夠進行下一步了。github

二.搭建 Spring框架

我此次搭建Spring框架採用了註解的方式,由於本次涉及的內容很少,因此採用註解的方式較爲簡單。首先咱們在resources目錄下新建一個applicationContext.xml文件做爲Spring的配置文件,內容以下:web

<?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">

    <!-- 開啓註解的掃描-->
    <context:component-scan base-package="com.robod">
        <!-- 配置哪些註解不掃描-->
        <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>

</beans>
複製代碼

而後在UserServiceImpl.java中實現UserService接口中的方法,而且爲其加上註解。spring

@Service("userService")
public class UserServiceImpl implements UserService {

    @Override
    public List<User> findAll() {
        System.out.println("如今調用了UserService中的findAll()方法");
        return null;
    }

    @Override
    public void save(List<User> users) {

    }
}
複製代碼

準備工做完成啦,如今咱們就能夠測試Spring框架搭建的有沒有問題了。咱們在test包下使用Junit進行單元測試,sql

public class TEST {

    @Test
    public void testSpring(){
		ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
        UserService userService = ac.getBean("userService",UserService.class);
        userService.findAll();
    }
}
複製代碼

運行一下,看有沒有結果

Spring搭建結果

運行結果出現了,說明咱們的Spring框架搭建的沒有問題,如今就能夠進行SpringMVC框架的搭建了。

三.搭建SpringMVC框架

配置SpringMVC框架首先咱們須要準備好SpringMVC的配置文件,在resources目錄下新建一個SpringMVC.xml文件,內容以下:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

    <!-- 1.開啓註解掃描,只掃描Controller註解-->
    <context:component-scan base-package="com.robod.controller">
        <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>

    <!-- 2.開啓SpringMVC註解的支持-->
    <mvc:annotation-driven/>
</beans>
複製代碼

光準備好配置文件可不夠,tomcat服務器在啓動的時候可不會去自動加載SpringMVC.xml文件,因此咱們接下來的工做就是要讓tomcat在啓動的時候就加載配置文件。打開webapp目錄下的WEB-INF文件夾,裏面有個web.xml文件,在裏面配置一個前端控制器,代碼以下:

<!-- 配置前端控制器-->
  <servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- 加載SpringMVC.xml配置文件-->
    <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>
  <servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>
複製代碼

如今就該配置路徑了,打開咱們在controller目錄下建立的UserController.java文件

@Controller
@RequestMapping("/user")
public class UserController {

    @RequestMapping("/findAll")
    public void findAll() {
        System.out.println("UserController中的findAll()方法執行了");
    }
}
複製代碼

如今訪問http://localhost:8080/ssmtest/user/findAll路徑就能夠執行findAll()方法了,啓動tomcat後在瀏覽器中輸入該路徑後按回車,看一下控制檯的打印:

SpringMVC搭建結果

OK,方法正常執行了,說明咱們的SpringMVC框架搭建成功了,如今就能夠進行Spring和SpringMVC框架的整合了。

四.Spring和SpringMVC框架的整合

終於能夠開始兩個框架的整合了。話很少說,讓咱們開始吧! 若是咱們能夠在controller中成功調用到service中的方法就說明咱們的框架整合沒有問題,以前咱們在單獨使用Spring的時候是手動加載Spring容器,放在這裏顯然不太合適,因此咱們須要在tomcat一啓動的時候就自動加載Spring容器,怎麼辦呢?咱們須要在web.xml中配置監聽器實現啓動時加載,添加如下內容:

<!-- Spring整合SpringMVC-->
  <!-- 配置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>
複製代碼

如今修改UserController,在裏面加入UserService,並調用UserService中的方法:

@Controller
@RequestMapping("/user")
public class UserController {

    @Autowired
    UserService userService;

    @RequestMapping("/findAll")
    public void findAll() {
        System.out.println("UserController中的findAll()方法執行了");
        userService.findAll();
    }

}
複製代碼

如今啓動tomcat服務器,訪問http://localhost:8080/ssmtest/user/findAll,看看執行結果。

Spring和SpringMVC框架的整合

很顯然,咱們的Spring框架和SpringMVC框架整合成功了,接下來咱們就能夠準備MyBatis框架了。

五.Spring框架整合MyBatis框架

原本我準備先搭建MyBatis框架,測一下有沒有問題再進行整合,可是單獨使用MyBatis框架須要準備配置文件,整合的時候又用不到,因此就跳過單獨測試MyBatis框架,直接一邊搭建一邊整合。 使用過MyBatis框架的朋友們都應該知道咱們在配置文件中配置了什麼,無非就是配置dataSource和引入映射配置文件兩件事情而已,而後在使用的時候就是建立SqlSession去初始化dao的實例。這些咱們均可以將其配置到Spring的容器中去,這樣就實現了Spring框架整合MyBatis框架。在applicationContext.xml文件中添加如下內容:

<!-- Spring整合MyBatis框架 -->
    <!-- 配置鏈接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="com.mysql.jdbc.Driver"/>
        <property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/ssmtest"/>
        <property name="user" value="root"/>
        <property name="password" value="123456"/>
    </bean>
    <!-- 配置SqlSessionFactory工廠 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
    </bean>
    <!-- 配置AccountDao接口所在包 -->
    <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.robod.dao"/>
</bean>
複製代碼

這樣咱們就能夠將其加載進Spring容器中了,接下來咱們就在UserDao中加上相應的註解,並在UserServiceImpl中調用UseDao中的相應方法,而後在UserController中打印結果: UserDao:

@Repository("userDao")
public interface UserDao {

    @Select("select * from user")
    public List<User> findAll();

    @Update("insert into user(name , age) values (#{name},#{age})")
    public void save(User user);

}

複製代碼

UserController:

@RequestMapping("/findAll")
    public void findAll() {
        System.out.println("UserController中的findAll()方法執行了");
        List<User> users = userService.findAll();
        for (User user : users) {
            System.out.println(user.toString());
        }
    }
複製代碼

這時候咱們的數據庫中尚未數據,咱們先隨便添加幾條數據,而後再啓動tomcat服務器,看一下結果:

Spring框架整合MyBatis框架

沒有問題,至此咱們的三大框架就整合完成啦!

六.Spring聲明式事務管理

Spring中有個很是強大的功能就是聲明式事務管理,咱們固然不能忘了。配置Spring聲明式事務管理有三個步驟,我在代碼里加了註釋,你們本身看,在applicationContext.xml中添加如下內容:

<!-- 配置Spring框架聲明式事務管理 -->
    <!-- (1)配置事務管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>
    <!-- (2)配置事務通知 -->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="find*" read-only="true"/>
            <tx:method name="*" isolation="DEFAULT"/>
        </tx:attributes>
    </tx:advice>
    <!-- (3)配置AOP加強 -->
    <aop:config>
        <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.playman.service.impl.*ServiceImpl.*(..))"/>
    </aop:config>
複製代碼

OK,如今咱們能夠來測試一下了,我在前面寫了一個save方法還沒用,就是準備測試聲明式事務管理的。 在UserController中添加一個save方法:

@RequestMapping("/save")
    public void saveAccounts() {
        User user1 = new User();
        user1.setId(1);
        user1.setName("li");
        user1.setAge(20);
        User user2 = new User();
        user2.setId(2);
        user2.setName("j");
        user2.setAge(25);
        List<User> accounts = new ArrayList<>();
        accounts.add(user1);
        accounts.add(user2);
        userService.save(accounts);
    }
複製代碼

而後將UserServiceImpl的save方法補充完整:

@Override
public void save(List<User> users) {
    User user1 = users.get(0);
    User user2 = users.get(1);
    userDao.save(user1);
    userDao.save(user2);
}
複製代碼

咱們啓動tomcat,訪問http://localhost:8080/ssmtest/user/save

Spring聲明式事務管理1

打開數據庫能夠看到,咱們的save方法是沒有問題的。如今爲了可以看到咱們的聲明式事務管理是否能夠正常運行,咱們人爲地加一點異常 ,修改UserServiceImpl的save方法:

@Override
    public void save(List<User> users) {
        User user1 = users.get(0);
        User user2 = users.get(1);
        userDao.save(user1);
        int i = 1/0;    //若是事務沒有回滾,那麼應該能夠正常添加一條數據
        userDao.save(user2);
    }
複製代碼

爲了看到對比的效果,咱們先把聲明式事務管理的配置刪除掉,再刪掉數據庫中咱們剛纔添加的數據,運行一下:

Spring聲明式事務管理2

Spring聲明式事務管理3

能夠看到,數據庫中添加了一條數據,說明再沒配置事務管理前出現異常是不會回滾的,如今咱們將剛纔刪掉的配置代碼再加上,刪除數據庫中的信息,再運行一下:

Spring聲明式事務管理4

Spring聲明式事務管理5

能夠看到,數據庫中一條數據都沒有添加,說明真的回滾了,咱們的聲明式事務管理就配置成功了。到如今,全部的操做就所有完成啦!

微信公衆號
相關文章
相關標籤/搜索