SSM框架——詳細整合教程(Spring+SpringMVC+MyBatis)

weixin_34166847發表於2018-01-23

使用SSM(Spring、SpringMVC和Mybatis)已經有三個多月了,專案在技術上已經沒有什麼難點了,基於現有的技術就可以實現想要的功能,當然肯定有很多可以改進的地方。之前沒有記錄SSM整合的過程,這次剛剛好基於自己的一個小專案重新搭建了一次,而且比專案搭建的要更好一些。以前解決問題的過程和方法並沒有及時記錄,以後在自己的小專案中遇到我再整理分享一下。這次,先說說三大框架整合過程。個人認為使用框架並不是很難,關鍵要理解其思想,這對於我們提高程式設計水平很有幫助。不過,如果用都不會,談思想就變成紙上談兵了!!!先技術,再思想。實踐出真知。(可通過圖片水印檢視部落格地址)


1、基本概念


1.1、Spring


Spring是一個開源框架,Spring是於2003 年興起的一個輕量級的Java 開發框架,由Rod Johnson 在其著作Expert One-On-One J2EE Development and Design中闡述的部分理念和原型衍生而來。它是為了解決企業應用開發的複雜性而建立的。Spring使用基本的JavaBean來完成以前只可能由EJB完成的事情。然而,Spring的用途不僅限於伺服器端的開發。從簡單性、可測試性和鬆耦合的角度而言,任何Java應用都可以從Spring中受益。 簡單來說,Spring是一個輕量級的控制反轉(IoC)和麵向切面(AOP)的容器框架。


1.2、SpringMVC

Spring MVC屬於SpringFrameWork的後續產品,已經融合在Spring Web Flow裡面。Spring MVC 分離了控制器、模型物件、分派器以及處理程式物件的角色,這種分離讓它們更容易進行定製。


1.3、MyBatis


MyBatis 本是apache的一個開源專案iBatis, 2010年這個專案由apache software foundation 遷移到了google code,並且改名為MyBatis 。MyBatis是一個基於Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)MyBatis 消除了幾乎所有的JDBC程式碼和引數的手工設定以及結果集的檢索。MyBatis 使用簡單的 XML或註解用於配置和原始對映,將介面和 Java 的POJOs(Plain Old Java Objects,普通的 Java物件)對映成資料庫中的記錄。



2、開發環境搭建



如果需要,參看之前的博文:blog.csdn.net/zhshulin/ar…



3、Maven Web專案建立


如果需要,參看之前的博文:blog.csdn.net/zhshulin/ar…



4、SSM整合

下面主要介紹三大框架的整合,至於環境的搭建以及專案的建立,參看上面的博文。這次整合我分了2個配置檔案,分別是spring-mybatis.xml,包含spring和mybatis的配置檔案,還有個是spring-mvc的配置檔案,此外有2個資原始檔:jdbc.propertis和log4j.properties。完整目錄結構如下(最後附上原始碼下載地址,不建議直接使用原始碼,因為此教程已經有了全部程式碼):


使用框架都是較新的版本:

Spring 4.0.2 RELEASE

Spring MVC 4.0.2 RELEASE

MyBatis 3.2.6


4.1、Maven引入需要的JAR包

為了方便後面說的時候不需要引入JAR包,我這裡直接給出所有需要的JAR包,這都是基本的JAR包,每個包的是幹什麼的都有註釋,就不再多說了。

pom.xml

  1. <properties>
  2. <!-- spring版本號 -->
  3. <spring.version>4.0.2.RELEASE</spring.version>
  4. <!-- mybatis版本號 -->
  5. <mybatis.version>3.2.6</mybatis.version>
  6. <!-- log4j日誌檔案管理包版本 -->
  7. <slf4j.version>1.7.7</slf4j.version>
  8. <log4j.version>1.2.17</log4j.version>
  9. </properties>
  10. <dependencies>
  11. <dependency>
  12. <groupId>junit</groupId>
  13. <artifactId>junit</artifactId>
  14. <version>4.11</version>
  15. <!-- 表示開發的時候引入,釋出的時候不會載入此包 -->
  16. <scope>test</scope>
  17. </dependency>
  18. <!-- spring核心包 -->
  19. <dependency>
  20. <groupId>org.springframework</groupId>
  21. <artifactId>spring-core</artifactId>
  22. <version>${spring.version}</version>
  23. </dependency>
  24. <dependency>
  25. <groupId>org.springframework</groupId>
  26. <artifactId>spring-web</artifactId>
  27. <version>${spring.version}</version>
  28. </dependency>
  29. <dependency>
  30. <groupId>org.springframework</groupId>
  31. <artifactId>spring-oxm</artifactId>
  32. <version>${spring.version}</version>
  33. </dependency>
  34. <dependency>
  35. <groupId>org.springframework</groupId>
  36. <artifactId>spring-tx</artifactId>
  37. <version>${spring.version}</version>
  38. </dependency>
  39. <dependency>
  40. <groupId>org.springframework</groupId>
  41. <artifactId>spring-jdbc</artifactId>
  42. <version>${spring.version}</version>
  43. </dependency>
  44. <dependency>
  45. <groupId>org.springframework</groupId>
  46. <artifactId>spring-webmvc</artifactId>
  47. <version>${spring.version}</version>
  48. </dependency>
  49. <dependency>
  50. <groupId>org.springframework</groupId>
  51. <artifactId>spring-aop</artifactId>
  52. <version>${spring.version}</version>
  53. </dependency>
  54. <dependency>
  55. <groupId>org.springframework</groupId>
  56. <artifactId>spring-context-support</artifactId>
  57. <version>${spring.version}</version>
  58. </dependency>
  59. <dependency>
  60. <groupId>org.springframework</groupId>
  61. <artifactId>spring-test</artifactId>
  62. <version>${spring.version}</version>
  63. </dependency>
  64. <!-- mybatis核心包 -->
  65. <dependency>
  66. <groupId>org.mybatis</groupId>
  67. <artifactId>mybatis</artifactId>
  68. <version>${mybatis.version}</version>
  69. </dependency>
  70. <!-- mybatis/spring包 -->
  71. <dependency>
  72. <groupId>org.mybatis</groupId>
  73. <artifactId>mybatis-spring</artifactId>
  74. <version>1.2.2</version>
  75. </dependency>
  76. <!-- 匯入java ee jar 包 -->
  77. <dependency>
  78. <groupId>javax</groupId>
  79. <artifactId>javaee-api</artifactId>
  80. <version>7.0</version>
  81. </dependency>
  82. <!-- 匯入Mysql資料庫連結jar包 -->
  83. <dependency>
  84. <groupId>mysql</groupId>
  85. <artifactId>mysql-connector-java</artifactId>
  86. <version>5.1.30</version>
  87. </dependency>
  88. <!-- 匯入dbcp的jar包,用來在applicationContext.xml中配置資料庫 -->
  89. <dependency>
  90. <groupId>commons-dbcp</groupId>
  91. <artifactId>commons-dbcp</artifactId>
  92. <version>1.2.2</version>
  93. </dependency>
  94. <!-- JSTL標籤類 -->
  95. <dependency>
  96. <groupId>jstl</groupId>
  97. <artifactId>jstl</artifactId>
  98. <version>1.2</version>
  99. </dependency>
  100. <!-- 日誌檔案管理包 -->
  101. <!-- log start -->
  102. <dependency>
  103. <groupId>log4j</groupId>
  104. <artifactId>log4j</artifactId>
  105. <version>${log4j.version}</version>
  106. </dependency>
  107. <!-- 格式化物件,方便輸出日誌 -->
  108. <dependency>
  109. <groupId>com.alibaba</groupId>
  110. <artifactId>fastjson</artifactId>
  111. <version>1.1.41</version>
  112. </dependency>
  113. <dependency>
  114. <groupId>org.slf4j</groupId>
  115. <artifactId>slf4j-api</artifactId>
  116. <version>${slf4j.version}</version>
  117. </dependency>
  118. <dependency>
  119. <groupId>org.slf4j</groupId>
  120. <artifactId>slf4j-log4j12</artifactId>
  121. <version>${slf4j.version}</version>
  122. </dependency>
  123. <!-- log end -->
  124. <!-- 映入JSON -->
  125. <dependency>
  126. <groupId>org.codehaus.jackson</groupId>
  127. <artifactId>jackson-mapper-asl</artifactId>
  128. <version>1.9.13</version>
  129. </dependency>
  130. <!-- 上傳元件包 -->
  131. <dependency>
  132. <groupId>commons-fileupload</groupId>
  133. <artifactId>commons-fileupload</artifactId>
  134. <version>1.3.1</version>
  135. </dependency>
  136. <dependency>
  137. <groupId>commons-io</groupId>
  138. <artifactId>commons-io</artifactId>
  139. <version>2.4</version>
  140. </dependency>
  141. <dependency>
  142. <groupId>commons-codec</groupId>
  143. <artifactId>commons-codec</artifactId>
  144. <version>1.9</version>
  145. </dependency>
  146. </dependencies>


4.2、Spring與MyBatis的整合

所有需要的JAR包都引入以後,首先進行Spring與MyBatis的整合,然後再進行JUnit測試,先看一個專案結構圖:


4.2.1、建立JDBC屬性檔案

jdbc.properties(檔案編碼修改為utf-8)

  1. driver=com.mysql.jdbc.Driver
  2. url=jdbc:mysql://10.221.10.111:8080/db_zsl
  3. username=demao
  4. password=demao
  5. #定義初始連線數
  6. initialSize=0
  7. #定義最大連線數
  8. maxActive=20
  9. #定義最大空閒
  10. maxIdle=20
  11. #定義最小空閒
  12. minIdle=1
  13. #定義最長等待時間
  14. maxWait=60000


4.2.2、建立spring-mybatis.xml配置檔案

這個檔案就是用來完成spring和mybatis的整合的。這裡面也沒多少行配置,主要的就是自動掃描,自動注入,配置資料庫。註釋也很詳細,大家看看就明白了。

spring-mybatis.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
  12. <!-- 自動掃描 -->
  13. <context:component-scan base-package="com.cn.hnust" />
  14. <!-- 引入配置檔案 -->
  15. <bean id="propertyConfigurer"
  16. class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  17. <property name="location" value="classpath:jdbc.properties" />
  18. </bean>
  19. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  20. destroy-method="close">
  21. <property name="driverClassName" value="${driver}" />
  22. <property name="url" value="${url}" />
  23. <property name="username" value="${username}" />
  24. <property name="password" value="${password}" />
  25. <!-- 初始化連線大小 -->
  26. <property name="initialSize" value="${initialSize}"></property>
  27. <!-- 連線池最大數量 -->
  28. <property name="maxActive" value="${maxActive}"></property>
  29. <!-- 連線池最大空閒 -->
  30. <property name="maxIdle" value="${maxIdle}"></property>
  31. <!-- 連線池最小空閒 -->
  32. <property name="minIdle" value="${minIdle}"></property>
  33. <!-- 獲取連線最大等待時間 -->
  34. <property name="maxWait" value="${maxWait}"></property>
  35. </bean>
  36. <!-- spring和MyBatis完美整合,不需要mybatis的配置對映檔案 -->
  37. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  38. <property name="dataSource" ref="dataSource" />
  39. <!-- 自動掃描mapping.xml檔案 -->
  40. <property name="mapperLocations" value="classpath:com/cn/hnust/mapping/*.xml"></property>
  41. </bean>
  42. <!-- DAO介面所在包名,Spring會自動查詢其下的類 -->
  43. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  44. <property name="basePackage" value="com.cn.hnust.dao" />
  45. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
  46. </bean>
  47. <!-- (事務管理)transaction manager, use JtaTransactionManager for global tx -->
  48. <bean id="transactionManager"
  49. class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  50. <property name="dataSource" ref="dataSource" />
  51. </bean>
  52. </beans>



4.2.3、Log4j的配置


為了方便除錯,一般都會使用日誌來輸出資訊,Log4j是Apache的一個開放原始碼專案,通過使用Log4j,我們可以控制日誌資訊輸送的目的地是控制檯、檔案、GUI元件,甚至是套介面伺服器、NT的事件記錄器、UNIX Syslog守護程式等;我們也可以控制每一條日誌的輸出格式;通過定義每一條日誌資訊的級別,我們能夠更加細緻地控制日誌的生成過程。

Log4j的配置很簡單,而且也是通用的,下面給出一個基本的配置,換到其他專案中也無需做多大的調整,如果想做調整或者想了解Log4j的各種配置,參看我轉載的一篇博文,很詳細:

blog.csdn.net/zhshulin/ar…

下面給出配置檔案目錄:


log4j.properties

  1. #定義LOG輸出級別
  2. log4j.rootLogger=INFO,Console,File
  3. #定義日誌輸出目的地為控制檯
  4. log4j.appender.Console=org.apache.log4j.ConsoleAppender
  5. log4j.appender.Console.Target=System.out
  6. #可以靈活地指定日誌輸出格式,下面一行是指定具體的格式
  7. log4j.appender.Console.layout = org.apache.log4j.PatternLayout
  8. log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n
  9. #檔案大小到達指定尺寸的時候產生一個新的檔案
  10. log4j.appender.File = org.apache.log4j.RollingFileAppender
  11. #指定輸出目錄
  12. log4j.appender.File.File = logs/ssm.log
  13. #定義檔案最大大小
  14. log4j.appender.File.MaxFileSize = 10MB
  15. # 輸出所以日誌,如果換成DEBUG表示輸出DEBUG以上級別日誌
  16. log4j.appender.File.Threshold = ALL
  17. log4j.appender.File.layout = org.apache.log4j.PatternLayout
  18. log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n


4.2.4、JUnit測試


經過以上步驟(到4.2.2,log4j不配也沒影響),我們已經完成了Spring和mybatis的整合,這樣我們就可以編寫一段測試程式碼來試試是否成功了。



4.2.4.1、建立測試用表

既然我們需要測試,那麼我們就需要建立在資料庫中建立一個測試表,這個表建的很簡單,SQL語句為:

  1. DROP TABLE IF EXISTS `user_t`;
  2. CREATE TABLE `user_t` (
  3. `id` int(11) NOT NULL AUTO_INCREMENT,
  4. `user_name` varchar(40) NOT NULL,
  5. `password` varchar(255) NOT NULL,
  6. `age` int(4) NOT NULL,
  7. PRIMARY KEY (`id`)
  8. ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
  9. /*Data for the table `user_t` */
  10. insert into `user_t`(`id`,`user_name`,`password`,`age`) values (1,'測試','sfasgfaf',24);


4.2.4.2、利用MyBatis Generator自動建立程式碼

參考博文:blog.csdn.net/zhshulin/ar…


這個可根據表自動建立實體類、MyBatis對映檔案以及DAO介面,當然,我習慣將生成的介面名改為IUserDao,而不是直接用它生成的UserMapper。如果不想麻煩就可以不改。完成後將檔案複製到工程中。如圖:

4.2.4.3、建立Service介面和實現類

目錄結構:


下面給出具體的內容:

IUserService.jave

  1. package com.cn.hnust.service;
  2. import com.cn.hnust.pojo.User;
  3. public interface IUserService {
  4. public User getUserById(int userId);
  5. }


UserServiceImpl.java

  1. package com.cn.hnust.service.impl;
  2. import javax.annotation.Resource;
  3. import org.springframework.stereotype.Service;
  4. import com.cn.hnust.dao.IUserDao;
  5. import com.cn.hnust.pojo.User;
  6. import com.cn.hnust.service.IUserService;
  7. @Service("userService")
  8. public class UserServiceImpl implements IUserService {
  9. @Resource
  10. private IUserDao userDao;
  11. @Override
  12. public User getUserById(int userId) {
  13. // TODO Auto-generated method stub
  14. return this.userDao.selectByPrimaryKey(userId);
  15. }
  16. }


4.2.4.4、建立測試類

測試類在src/test/java中建立,下面測試類中註釋掉的部分是不使用Spring時,一般情況下的一種測試方法;如果使用了Spring那麼就可以使用註解的方式來引入配置檔案和類,然後再將service介面物件注入,就可以進行測試了。

如果測試成功,表示Spring和Mybatis已經整合成功了。輸出資訊使用的是Log4j列印到控制檯。


  1. package org.zsl.testmybatis;
  2. import javax.annotation.Resource;
  3. import org.apache.log4j.Logger;
  4. import org.junit.Before;
  5. import org.junit.Test;
  6. import org.junit.runner.RunWith;
  7. import org.springframework.context.ApplicationContext;
  8. import org.springframework.context.support.ClassPathXmlApplicationContext;
  9. import org.springframework.test.context.ContextConfiguration;
  10. import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
  11. import com.alibaba.fastjson.JSON;
  12. import com.cn.hnust.pojo.User;
  13. import com.cn.hnust.service.IUserService;
  14. @RunWith(SpringJUnit4ClassRunner.class) //表示繼承了SpringJUnit4ClassRunner類
  15. @ContextConfiguration(locations = {"classpath:spring-mybatis.xml"})
  16. public class TestMyBatis {
  17. private static Logger logger = Logger.getLogger(TestMyBatis.class);
  18. // private ApplicationContext ac = null;
  19. @Resource
  20. private IUserService userService = null;
  21. // @Before
  22. // public void before() {
  23. // ac = new ClassPathXmlApplicationContext("applicationContext.xml");
  24. // userService = (IUserService) ac.getBean("userService");
  25. // }
  26. @Test
  27. public void test1() {
  28. User user = userService.getUserById(1);
  29. // System.out.println(user.getUserName());
  30. // logger.info("值:"+user.getUserName());
  31. logger.info(JSON.toJSONString(user));
  32. }  


測試結果:



至此,完成Spring和mybatis這兩大框架的整合,下面在繼續進行SpringMVC的整合。


4.3、整合SpringMVC

上面已經完成了2大框架的整合,SpringMVC的配置檔案單獨放,然後在web.xml中配置整合。

4.3.1、配置spring-mvc.xml

配置裡面的註釋也很詳細,在此就不說了,主要是自動掃描控制器,檢視模式,註解的啟動這三個。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
  12. <!-- 自動掃描該包,使SpringMVC認為包下用了@controller註解的類是控制器 -->
  13. <context:component-scan base-package="com.cn.hnust.controller" />
  14. <!--避免IE執行AJAX時,返回JSON出現下載檔案 -->
  15. <bean id="mappingJacksonHttpMessageConverter"
  16. class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
  17. <property name="supportedMediaTypes">
  18. <list>
  19. <value>text/html;charset=UTF-8</value>
  20. </list>
  21. </property>
  22. </bean>
  23. <!-- 啟動SpringMVC的註解功能,完成請求和註解POJO的對映 -->
  24. <bean
  25. class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
  26. <property name="messageConverters">
  27. <list>
  28. <ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON轉換器 -->
  29. </list>
  30. </property>
  31. </bean>
  32. <!-- 定義跳轉的檔案的前字尾 ,檢視模式配置-->
  33. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  34. <!-- 這裡的配置我的理解是自動給後面action的方法return的字串加上字首和字尾,變成一個 可用的url地址 -->
  35. <property name="prefix" value="/WEB-INF/jsp/" />
  36. <property name="suffix" value=".jsp" />
  37. </bean>
  38. <!-- 配置檔案上傳,如果沒有使用檔案上傳可以不用配置,當然如果不配,那麼配置檔案中也不必引入上傳元件包 -->
  39. <bean id="multipartResolver"
  40. class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  41. <!-- 預設編碼 -->
  42. <property name="defaultEncoding" value="utf-8" />
  43. <!-- 檔案大小最大值 -->
  44. <property name="maxUploadSize" value="10485760000" />
  45. <!-- 記憶體中的最大值 -->
  46. <property name="maxInMemorySize" value="40960" />
  47. </bean>
  48. </beans>


4.3.2、配置web.xml檔案

這裡面對spring-mybatis.xml的引入以及配置的spring-mvc的Servlet就是為了完成SSM整合,之前2框架整合不需要在此處進行任何配置。配置一樣有詳細註釋,不多解釋了。


web.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns="http://java.sun.com/xml/ns/javaee"
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
  5. version="3.0">
  6. <display-name>Archetype Created Web Application</display-name>
  7. <!-- Spring和mybatis的配置檔案 -->
  8. <context-param>
  9. <param-name>contextConfigLocation</param-name>
  10. <param-value>classpath:spring-mybatis.xml</param-value>
  11. </context-param>
  12. <!-- 編碼過濾器 -->
  13. <filter>
  14. <filter-name>encodingFilter</filter-name>
  15. <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  16. <async-supported>true</async-supported>
  17. <init-param>
  18. <param-name>encoding</param-name>
  19. <param-value>UTF-8</param-value>
  20. </init-param>
  21. </filter>
  22. <filter-mapping>
  23. <filter-name>encodingFilter</filter-name>
  24. <url-pattern>/*</url-pattern>
  25. </filter-mapping>
  26. <!-- Spring監聽器 -->
  27. <listener>
  28. <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  29. </listener>
  30. <!-- 防止Spring記憶體溢位監聽器 -->
  31. <listener>
  32. <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
  33. </listener>
  34. <!-- Spring MVC servlet -->
  35. <servlet>
  36. <servlet-name>SpringMVC</servlet-name>
  37. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  38. <init-param>
  39. <param-name>contextConfigLocation</param-name>
  40. <param-value>classpath:spring-mvc.xml</param-value>
  41. </init-param>
  42. <load-on-startup>1</load-on-startup>
  43. <async-supported>true</async-supported>
  44. </servlet>
  45. <servlet-mapping>
  46. <servlet-name>SpringMVC</servlet-name>
  47. <!-- 此處可以可以配置成*.do,對應struts的字尾習慣 -->
  48. <url-pattern>/</url-pattern>
  49. </servlet-mapping>
  50. <welcome-file-list>
  51. <welcome-file>/index.jsp</welcome-file>
  52. </welcome-file-list>
  53. </web-app>


4.3.3、測試

至此已經完成了SSM三大框架的整合了,接下來測試一下,如果成功了,那麼恭喜你,如果失敗了,繼續除錯吧,作為程式設計師就是不停的與BUG做鬥爭!


4.3.3.1、新建jsp頁面


showUser.jsp 此頁面僅輸出一下使用者名稱,完成一個完整的簡單流程。

  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
  2. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  3. <html>
  4. <head>
  5. <title>測試</title>
  6. </head>
  7. <body>
  8. ${user.userName}
  9. </body>
  10. </html>


4.3.3.2、建立UserController類

UserController.java 控制器

  1. package com.cn.hnust.controller;
  2. import javax.annotation.Resource;
  3. import javax.servlet.http.HttpServletRequest;
  4. import org.springframework.stereotype.Controller;
  5. import org.springframework.ui.Model;
  6. import org.springframework.web.bind.annotation.RequestMapping;
  7. import com.cn.hnust.pojo.User;
  8. import com.cn.hnust.service.IUserService;
  9. @Controller
  10. @RequestMapping("/user")
  11. public class UserController {
  12. @Resource
  13. private IUserService userService;
  14. @RequestMapping("/showUser")
  15. public String toIndex(HttpServletRequest request,Model model){
  16. int userId = Integer.parseInt(request.getParameter("id"));
  17. User user = this.userService.getUserById(userId);
  18. model.addAttribute("user", user);
  19. return "showUser";
  20. }
  21. }


4.3.3.3、部署專案

輸入地址:localhost:8080/專案名稱/user/showUser?id=1

至此,SSM三大框架的整合就完成了,在此基礎上可再新增其他功能。


相關文章