SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

梦里梦外; 2021-10-09 09:48 373阅读 0赞

使用SSM(Spring、SpringMVC和Mybatis)已经有三个多月了,项目在技术上已经没有什么难点了,基于现有的技术就可以实现想要的功能,当然肯定有很多可以改进的地方。之前没有记录SSM整合的过程,这次刚刚好基于自己的一个小项目重新搭建了一次,而且比项目搭建的要更好一些。以前解决问题的过程和方法并没有及时记录,以后在自己的小项目中遇到我再整理分享一下。这次,先说说三大框架整合过程。个人认为使用框架并不是很难,关键要理解其思想,这对于我们提高编程水平很有帮助。不过,如果用都不会,谈思想就变成纸上谈兵了!!!先技术,再思想。实践出真知。(可通过图片水印查看博客地址)

1、基本概念

1.1、Spring

  1. 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

  1. Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring MVC 分离了[控制器][Link 1]、模型[对象][Link 2]、分派器以及处理程序对象的角色,这种分离让它们更容易进行定制。

1.3、MyBatis

  1. MyBatis 本是[apache][]的一个开源项目[iBatis][], 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis MyBatis是一个基于Java的[持久层][Link 3]框架。iBATIS提供的[持久层][Link 3]框架包括SQL MapsData Access ObjectsDAOMyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java POJOsPlain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

2、开发环境搭建

如果需要,参看之前的博文:http://blog.csdn.net/zhshulin/article/details/30779873

3、Maven Web项目创建

如果需要,参看之前的博文:http://blog.csdn.net/zhshulin/article/details/37921705

4、SSM整合

  1. 下面主要介绍三大框架的整合,至于环境的搭建以及项目的创建,参看上面的博文。这次整合我分了2个配置文件,分别是spring-mybatis.xml,包含springmybatis的配置文件,还有个是spring-mvc的配置文件,此外有2个资源文件:jdbc.propertislog4j.properties。完整目录结构如下(最后附上源码下载地址,不建议直接使用源码,因为此教程已经有了全部代码):

SouthEast

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

  1. Spring 4.0.2 RELEASE
  2. Spring MVC 4.0.2 RELEASE
  3. MyBatis 3.2.6

4.1、Maven引入需要的JAR包

  1. 为了方便后面说的时候不需要引入JAR包,我这里直接给出所有需要的JAR包,这都是基本的JAR包,每个包的是干什么的都有注释,就不再多说了。

pom.xml

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. <**properties**>
  2. <**spring.version**>4.0.2.RELEASE</**spring.version**>
  3. <**mybatis.version**>3.2.6</**mybatis.version**>
  4. <**slf4j.version**>1.7.7</**slf4j.version**>
  5. <**log4j.version**>1.2.17</**log4j.version**>
  6. </**properties**>
  7. <**dependencies**>
  8. <**dependency**>
  9. <**groupId**>junit</**groupId**>
  10. <**artifactId**>junit</**artifactId**>
  11. <**version**>4.11</**version**>
  12. <**scope**>test</**scope**>
  13. </**dependency**>
  14. <**dependency**>
  15. <**groupId**>org.springframework</**groupId**>
  16. <**artifactId**>spring-core</**artifactId**>
  17. <**version**>${spring.version}</**version**>
  18. </**dependency**>
  19. <**dependency**>
  20. <**groupId**>org.springframework</**groupId**>
  21. <**artifactId**>spring-web</**artifactId**>
  22. <**version**>${spring.version}</**version**>
  23. </**dependency**>
  24. <**dependency**>
  25. <**groupId**>org.springframework</**groupId**>
  26. <**artifactId**>spring-oxm</**artifactId**>
  27. <**version**>${spring.version}</**version**>
  28. </**dependency**>
  29. <**dependency**>
  30. <**groupId**>org.springframework</**groupId**>
  31. <**artifactId**>spring-tx</**artifactId**>
  32. <**version**>${spring.version}</**version**>
  33. </**dependency**>
  34. <**dependency**>
  35. <**groupId**>org.springframework</**groupId**>
  36. <**artifactId**>spring-jdbc</**artifactId**>
  37. <**version**>${spring.version}</**version**>
  38. </**dependency**>
  39. <**dependency**>
  40. <**groupId**>org.springframework</**groupId**>
  41. <**artifactId**>spring-webmvc</**artifactId**>
  42. <**version**>${spring.version}</**version**>
  43. </**dependency**>
  44. <**dependency**>
  45. <**groupId**>org.springframework</**groupId**>
  46. <**artifactId**>spring-aop</**artifactId**>
  47. <**version**>${spring.version}</**version**>
  48. </**dependency**>
  49. <**dependency**>
  50. <**groupId**>org.springframework</**groupId**>
  51. <**artifactId**>spring-context-support</**artifactId**>
  52. <**version**>${spring.version}</**version**>
  53. </**dependency**>
  54. <**dependency**>
  55. <**groupId**>org.springframework</**groupId**>
  56. <**artifactId**>spring-test</**artifactId**>
  57. <**version**>${spring.version}</**version**>
  58. </**dependency**>
  59. <**dependency**>
  60. <**groupId**>org.mybatis</**groupId**>
  61. <**artifactId**>mybatis</**artifactId**>
  62. <**version**>${mybatis.version}</**version**>
  63. </**dependency**>
  64. <**dependency**>
  65. <**groupId**>org.mybatis</**groupId**>
  66. <**artifactId**>mybatis-spring</**artifactId**>
  67. <**version**>1.2.2</**version**>
  68. </**dependency**>
  69. <**dependency**>
  70. <**groupId**>javax</**groupId**>
  71. <**artifactId**>javaee-api</**artifactId**>
  72. <**version**>7.0</**version**>
  73. </**dependency**>
  74. <**dependency**>
  75. <**groupId**>mysql</**groupId**>
  76. <**artifactId**>mysql-connector-java</**artifactId**>
  77. <**version**>5.1.30</**version**>
  78. </**dependency**>
  79. <**dependency**>
  80. <**groupId**>commons-dbcp</**groupId**>
  81. <**artifactId**>commons-dbcp</**artifactId**>
  82. <**version**>1.2.2</**version**>
  83. </**dependency**>
  84. <**dependency**>
  85. <**groupId**>jstl</**groupId**>
  86. <**artifactId**>jstl</**artifactId**>
  87. <**version**>1.2</**version**>
  88. </**dependency**>
  89. <**dependency**>
  90. <**groupId**>log4j</**groupId**>
  91. <**artifactId**>log4j</**artifactId**>
  92. <**version**>${log4j.version}</**version**>
  93. </**dependency**>
  94. <**dependency**>
  95. <**groupId**>com.alibaba</**groupId**>
  96. <**artifactId**>fastjson</**artifactId**>
  97. <**version**>1.1.41</**version**>
  98. </**dependency**>
  99. <**dependency**>
  100. <**groupId**>org.slf4j</**groupId**>
  101. <**artifactId**>slf4j-api</**artifactId**>
  102. <**version**>${slf4j.version}</**version**>
  103. </**dependency**>
  104. <**dependency**>
  105. <**groupId**>org.slf4j</**groupId**>
  106. <**artifactId**>slf4j-log4j12</**artifactId**>
  107. <**version**>${slf4j.version}</**version**>
  108. </**dependency**>
  109. <**dependency**>
  110. <**groupId**>org.codehaus.jackson</**groupId**>
  111. <**artifactId**>jackson-mapper-asl</**artifactId**>
  112. <**version**>1.9.13</**version**>
  113. </**dependency**>
  114. <**dependency**>
  115. <**groupId**>commons-fileupload</**groupId**>
  116. <**artifactId**>commons-fileupload</**artifactId**>
  117. <**version**>1.3.1</**version**>
  118. </**dependency**>
  119. <**dependency**>
  120. <**groupId**>commons-io</**groupId**>
  121. <**artifactId**>commons-io</**artifactId**>
  122. <**version**>2.4</**version**>
  123. </**dependency**>
  124. <**dependency**>
  125. <**groupId**>commons-codec</**groupId**>
  126. <**artifactId**>commons-codec</**artifactId**>
  127. <**version**>1.9</**version**>
  128. </**dependency**>
  129. </**dependencies**>

4.2、Spring与MyBatis的整合

所有需要的JAR包都引入以后,首先进行Spring与MyBatis的整合,然后再进行JUnit测试,先看一个项目结构图:

Center

4.2.1、建立JDBC属性文件

jdbc.properties(文件编码修改为utf-8)

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  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配置文件

  1. 这个文件就是用来完成springmybatis的整合的。这里面也没多少行配置,主要的就是自动扫描,自动注入,配置数据库。注释也很详细,大家看看就明白了。

spring-mybatis.xml

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  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. <**context:component-scan base-package=”com.cn.hnust” />**
  13. <**bean** id=”propertyConfigurer”
  14. class=”org.springframework.beans.factory.config.PropertyPlaceholderConfigurer”>
  15. <**property name=”location” value=”classpath:jdbc.properties” />**
  16. </**bean**>
  17. <**bean** id=”dataSource” class=”org.apache.commons.dbcp.BasicDataSource”
  18. destroy-method=”close”>
  19. <**property name=”driverClassName” value=”${driver}“ />**
  20. <**property name=”url” value=”${url}“ />**
  21. <**property name=”username” value=”${username}“ />**
  22. <**property name=”password” value=”${password}“ />**
  23. <**property name=”initialSize” value=”${initialSize}“></property**>
  24. <**property name=”maxActive” value=”${maxActive}“></property**>
  25. <**property name=”maxIdle” value=”${maxIdle}“></property**>
  26. <**property name=”minIdle” value=”${minIdle}“></property**>
  27. <**property name=”maxWait” value=”${maxWait}“></property**>
  28. </**bean**>
  29. <**bean id=”sqlSessionFactory” class=”org.mybatis.spring.SqlSessionFactoryBean”>**
  30. <**property name=”dataSource” ref=”dataSource” />**
  31. <**property name=”mapperLocations” value=”classpath:com/cn/hnust/mapping/*.xml”></property**>
  32. </**bean**>
  33. <**bean class=”org.mybatis.spring.mapper.MapperScannerConfigurer”>**
  34. <**property name=”basePackage” value=”com.cn.hnust.dao” />**
  35. <**property name=”sqlSessionFactoryBeanName” value=”sqlSessionFactory”></property**>
  36. </**bean**>
  37. <**bean** id=”transactionManager”
  38. class=”org.springframework.jdbc.datasource.DataSourceTransactionManager”>
  39. <**property name=”dataSource” ref=”dataSource” />**
  40. </**bean**>
  41. </**beans**>

4.2.3、Log4j的配置

  1. 为了方便调试,一般都会使用日志来输出信息,Log4j是[Apache][]的一个开放源代码项目,通过使用Log4j,我们可以控制[日志][Link 4]信息输送的目的地是[控制台][Link 5]、文件、[GUI][]组件,甚至是套接口服务器、[NT][]的事件记录器、[UNIX][] [Syslog][][守护进程][Link 6]等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。
  2. Log4j的配置很简单,而且也是通用的,下面给出一个基本的配置,换到其他项目中也无需做多大的调整,如果想做调整或者想了解Log4j的各种配置,参看我转载的一篇博文,很详细:

http://blog.csdn.net/zhshulin/article/details/37937365

下面给出配置文件目录:

Center 1

log4j.properties

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  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测试

  1. 经过以上步骤(到4.2.2log4j不配也没影响),我们已经完成了Springmybatis的整合,这样我们就可以编写一段测试代码来试试是否成功了。

4.2.4.1、创建测试用表

既然我们需要测试,那么我们就需要建立在数据库中建立一个测试表,这个表建的很简单,SQL语句为:

[sql] view plain copy 在CODE上查看代码片 派生到我的代码片

  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自动创建代码

参考博文:http://blog.csdn.net/zhshulin/article/details/23912615

  1. 这个可根据表自动创建实体类、MyBatis映射文件以及DAO接口,当然,我习惯将生成的接口名改为IUserDao,而不是直接用它生成的UserMapper。如果不想麻烦就可以不改。完成后将文件复制到工程中。如图:

Center 2

4.2.4.3、建立Service接口和实现类

目录结构:

Center 3

下面给出具体的内容:

IUserService.jave

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  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

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  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、建立测试类

  1. 测试类在src/test/java中建立,下面测试类中注释掉的部分是不使用Spring时,一般情况下的一种测试方法;如果使用了Spring那么就可以使用注解的方式来引入配置文件和类,然后再将service接口对象注入,就可以进行测试了。
  2. 如果测试成功,表示SpringMybatis已经整合成功了。输出信息使用的是Log4j打印到控制台。

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  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. }
  33. }

测试结果:

Center 4

至此,完成Spring和mybatis这两大框架的整合,下面在继续进行SpringMVC的整合。

4.3、整合SpringMVC

  1. 上面已经完成了2大框架的整合,SpringMVC的配置文件单独放,然后在web.xml中配置整合。

4.3.1、配置spring-mvc.xml

配置里面的注释也很详细,在此就不说了,主要是自动扫描控制器,视图模式,注解的启动这三个。

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  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. <**context:component-scan base-package=”com.cn.hnust.controller” />**
  13. <**bean** id=”mappingJacksonHttpMessageConverter”
  14. class=”org.springframework.http.converter.json.MappingJacksonHttpMessageConverter”>
  15. <**property name=”supportedMediaTypes”>**
  16. <**list**>
  17. <**value**>text/html;charset=UTF-8</**value**>
  18. </**list**>
  19. </**property**>
  20. </**bean**>
  21. <**bean**
  22. class=”org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter”>
  23. <**property name=”messageConverters”>**
  24. <**list**>
  25. <**ref bean=”mappingJacksonHttpMessageConverter” />**
  26. </**list**>
  27. </**property**>
  28. </**bean**>
  29. <**bean class=”org.springframework.web.servlet.view.InternalResourceViewResolver”>**
  30. <**property name=”prefix” value=”/WEB-INF/jsp/“ />**
  31. <**property name=”suffix” value=”.jsp” />**
  32. </**bean**>
  33. <**bean** id=”multipartResolver”
  34. class=”org.springframework.web.multipart.commons.CommonsMultipartResolver”>
  35. <**property name=”defaultEncoding” value=”utf-8” />**
  36. <**property name=”maxUploadSize” value=”10485760000” />**
  37. <**property name=”maxInMemorySize” value=”40960” />**
  38. </**bean**>
  39. </**beans**>

4.3.2、配置web.xml文件

  1. 这里面对spring-mybatis.xml的引入以及配置的spring-mvcServlet就是为了完成SSM整合,之前2框架整合不需要在此处进行任何配置。配置一样有详细注释,不多解释了。

web.xml

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  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. <**context-param**>
  8. <**param-name**>contextConfigLocation</**param-name**>
  9. <**param-value**>classpath:spring-mybatis.xml</**param-value**>
  10. </**context-param**>
  11. <**filter**>
  12. <**filter-name**>encodingFilter</**filter-name**>
  13. <**filter-class**>org.springframework.web.filter.CharacterEncodingFilter</**filter-class**>
  14. <**async-supported**>true</**async-supported**>
  15. <**init-param**>
  16. <**param-name**>encoding</**param-name**>
  17. <**param-value**>UTF-8</**param-value**>
  18. </**init-param**>
  19. </**filter**>
  20. <**filter-mapping**>
  21. <**filter-name**>encodingFilter</**filter-name**>
  22. <**url-pattern**>/*</**url-pattern**>
  23. </**filter-mapping**>
  24. <**listener**>
  25. <**listener-class**>org.springframework.web.context.ContextLoaderListener</**listener-class**>
  26. </**listener**>
  27. <**listener**>
  28. <**listener-class**>org.springframework.web.util.IntrospectorCleanupListener</**listener-class**>
  29. </**listener**>
  30. <**servlet**>
  31. <**servlet-name**>SpringMVC</**servlet-name**>
  32. <**servlet-class**>org.springframework.web.servlet.DispatcherServlet</**servlet-class**>
  33. <**init-param**>
  34. <**param-name**>contextConfigLocation</**param-name**>
  35. <**param-value**>classpath:spring-mvc.xml</**param-value**>
  36. </**init-param**>
  37. <**load-on-startup**>1</**load-on-startup**>
  38. <**async-supported**>true</**async-supported**>
  39. </**servlet**>
  40. <**servlet-mapping**>
  41. <**servlet-name**>SpringMVC</**servlet-name**>
  42. <**url-pattern**>/</**url-pattern**>
  43. </**servlet-mapping**>
  44. <**welcome-file-list**>
  45. <**welcome-file**>/index.jsp</**welcome-file**>
  46. </**welcome-file-list**>
  47. </**web-app**>

4.3.3、测试

  1. 至此已经完成了SSM三大框架的整合了,接下来测试一下,如果成功了,那么恭喜你,如果失败了,继续调试吧,作为程序员就是不停的与BUG做斗争!

4.3.3.1、新建jsp页面

Center 5

showUser.jsp 此页面仅输出一下用户名,完成一个完整的简单流程。

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  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 控制器

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  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

Center 6

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

源码下载地址:http://download.csdn.net/detail/u012909091/7658611

发表评论

表情:
评论列表 (有 0 条评论,373人围观)

还没有评论,来说两句吧...

相关阅读