SSM框架整合
1,开发环境的搭建
JDK+Eclipse+Tomcat+Maven的安装与配置
参考:http://blog.csdn.net/zhshulin/article/details/30779873
2,Maven Web项目创建
创建一个Maven项目来配置环境
参考:http://blog.csdn.net/zhshulin/article/details/37921705
3,SSM的整合
2个配置文件:
① spring-mybatis.xml,包含spring和mybatis的配置文件,
②spring-mvc的配置文件,
2个资源文件:
①jdbc.propertis
②log4j.properties
目录结构:

3.1框架中引入的Jar包(pom.xml配置,也可以直接导入包)
1 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
2 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
3 <modelVersion>4.0.0</modelVersion>
4 <groupId>org.projectManagement</groupId>
5 <artifactId>projectManagement</artifactId>
6 <packaging>war</packaging>
7 <version>0.0.1-SNAPSHOT</version>
8 <name>projectManagement Maven Webapp</name>
9 <url>http://maven.apache.org</url>
10
11 <properties>
12 <!-- spring版本号 -->
13 <spring.version>4.0.2.RELEASE</spring.version>
14 <!-- mybatis版本号 -->
15 <mybatis.version>3.2.6</mybatis.version>
16 <!-- log4j日志文件管理包版本 -->
17 <slf4j.version>1.7.7</slf4j.version>
18 <log4j.version>1.2.17</log4j.version>
19 </properties>
20 <dependencies>
21 <!-- 导入java ee jar 包 -->
22 <dependency>
23 <groupId>org.apache.openejb</groupId>
24 <artifactId>javaee-api</artifactId>
25 <version>6.0-1</version>
26 </dependency>
27 <dependency>
28 <groupId>junit</groupId>
29 <artifactId>junit</artifactId>
30 <version>4.11</version>
31 <!-- 表示开发的时候引入,发布的时候不会加载此包 -->
32 <scope>test</scope>
33 </dependency>
34 <!-- spring核心包 -->
35 <dependency>
36 <groupId>org.springframework</groupId>
37 <artifactId>spring-core</artifactId>
38 <version>${spring.version}</version>
39 </dependency>
40
41 <dependency>
42 <groupId>org.springframework</groupId>
43 <artifactId>spring-web</artifactId>
44 <version>${spring.version}</version>
45 </dependency>
46 <dependency>
47 <groupId>org.springframework</groupId>
48 <artifactId>spring-oxm</artifactId>
49 <version>${spring.version}</version>
50 </dependency>
51 <dependency>
52 <groupId>org.springframework</groupId>
53 <artifactId>spring-tx</artifactId>
54 <version>${spring.version}</version>
55 </dependency>
56
57 <dependency>
58 <groupId>org.springframework</groupId>
59 <artifactId>spring-jdbc</artifactId>
60 <version>${spring.version}</version>
61 </dependency>
62
63 <dependency>
64 <groupId>org.springframework</groupId>
65 <artifactId>spring-webmvc</artifactId>
66 <version>${spring.version}</version>
67 </dependency>
68 <dependency>
69 <groupId>org.springframework</groupId>
70 <artifactId>spring-aop</artifactId>
71 <version>${spring.version}</version>
72 </dependency>
73
74 <dependency>
75 <groupId>org.springframework</groupId>
76 <artifactId>spring-context-support</artifactId>
77 <version>${spring.version}</version>
78 </dependency>
79
80 <dependency>
81 <groupId>org.springframework</groupId>
82 <artifactId>spring-test</artifactId>
83 <version>${spring.version}</version>
84 </dependency>
85 <!-- mybatis核心包 -->
86 <dependency>
87 <groupId>org.mybatis</groupId>
88 <artifactId>mybatis</artifactId>
89 <version>${mybatis.version}</version>
90 </dependency>
91 <!-- mybatis/spring包 -->
92 <dependency>
93 <groupId>org.mybatis</groupId>
94 <artifactId>mybatis-spring</artifactId>
95 <version>1.2.2</version>
96 </dependency>
97 <!-- 导入Mysql数据库链接jar包 -->
98 <dependency>
99 <groupId>mysql</groupId>
100 <artifactId>mysql-connector-java</artifactId>
101 <version>5.1.30</version>
102 </dependency>
103 <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 -->
104 <dependency>
105 <groupId>commons-dbcp</groupId>
106 <artifactId>commons-dbcp</artifactId>
107 <version>1.2.2</version>
108 </dependency>
109 <!-- JSTL标签类 -->
110 <dependency>
111 <groupId>jstl</groupId>
112 <artifactId>jstl</artifactId>
113 <version>1.2</version>
114 </dependency>
115 <!-- 日志文件管理包 -->
116 <!-- log start -->
117 <dependency>
118 <groupId>log4j</groupId>
119 <artifactId>log4j</artifactId>
120 <version>${log4j.version}</version>
121 </dependency>
122
123
124 <!-- 格式化对象,方便输出日志 -->
125 <dependency>
126 <groupId>com.alibaba</groupId>
127 <artifactId>fastjson</artifactId>
128 <version>1.1.41</version>
129 </dependency>
130
131
132 <dependency>
133 <groupId>org.slf4j</groupId>
134 <artifactId>slf4j-api</artifactId>
135 <version>${slf4j.version}</version>
136 </dependency>
137
138 <dependency>
139 <groupId>org.slf4j</groupId>
140 <artifactId>slf4j-log4j12</artifactId>
141 <version>${slf4j.version}</version>
142 </dependency>
143 <!-- log end -->
144 <!-- 映入JSON -->
145 <dependency>
146 <groupId>org.codehaus.jackson</groupId>
147 <artifactId>jackson-mapper-asl</artifactId>
148 <version>1.9.13</version>
149 </dependency>
150 <!-- 上传组件包 -->
151 <dependency>
152 <groupId>commons-fileupload</groupId>
153 <artifactId>commons-fileupload</artifactId>
154 <version>1.3.1</version>
155 </dependency>
156 <dependency>
157 <groupId>commons-io</groupId>
158 <artifactId>commons-io</artifactId>
159 <version>2.4</version>
160 </dependency>
161 <dependency>
162 <groupId>commons-codec</groupId>
163 <artifactId>commons-codec</artifactId>
164 <version>1.9</version>
165 </dependency>
166 <dependency>
167 <groupId>org.mybatis.generator</groupId>
168 <artifactId>mybatis-generator-maven-plugin</artifactId>
169 <version>1.3.2</version>
170 </dependency>
171 </dependencies>
172 <build>
173 <plugins>
174 <plugin>
175 <groupId>org.apache.maven.plugins</groupId>
176 <artifactId>maven-compiler-plugin</artifactId>
177 <configuration>
178 <source>1.8</source>
179 <target>1.8</target>
180 </configuration>
181 </plugin>
182 </plugins>
183 <finalName>projectManagement</finalName>
184 </build>
185 </project>
3.2、Spring与MyBatis的整合
所有需要的JAR包都引入以后,首先进行Spring与MyBatis的整合,然后再进行JUnit测试,
3.2.1、建立JDBC属性文件(jdbc.properties,文件编码修改为utf-8)
1 #<?xml version="1.0" encoding="UTF-8"?> 2 driver=com.mysql.jdbc.Driver 3 url=jdbc:mysql://localhost:3306/数据库名?useUnicode=true&characterEncoding=utf8 4 username=用户名 5 password=密码 6 #定义初始连接数 7 initialSize=0 8 #定义最大连接数 9 maxActive=20 10 #定义最大空闲 11 maxIdle=20 12 #定义最小空闲 13 minIdle=1 14 #定义最长等待时间 15 maxWait=60000
3.2.2、建立spring-mybatis.xml配置文件
这个文件就是用来完成spring和mybatis的整合的,主要的就是自动扫描,自动注入,配置数据库。
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.projMgr(包名要改)" />
14 <!-- 引入配置文件<property resource="classpath:jdbc.properties" /> -->
15 <bean id="propertyConfigurer"
16 class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
17 <property name="location" value="classpath:jdbc.properties" />
18
19 </bean>
20
21 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
22 destroy-method="close">
23 <property name="driverClassName" value="${driver}" />
24 <property name="url" value="${url}" />
25 <property name="username" value="${username}" />
26 <property name="password" value="${password}" />
27 <!-- 初始化连接大小 -->
28 <property name="initialSize" value="${initialSize}"></property>
29 <!-- 连接池最大数量 -->
30 <property name="maxActive" value="${maxActive}"></property>
31 <!-- 连接池最大空闲 -->
32 <property name="maxIdle" value="${maxIdle}"></property>
33 <!-- 连接池最小空闲 -->
34 <property name="minIdle" value="${minIdle}"></property>
35 <!-- 获取连接最大等待时间 -->
36 <property name="maxWait" value="${maxWait}"></property>
37 </bean>
38
39 <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
40 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
41 <property name="dataSource" ref="dataSource" />
42 <!-- 自动扫描mapping.xml文件 -->
43 <property name="mapperLocations" value="classpath:com/projMgr/mapping/*.xml"></property>
44 </bean>
45
46 <!-- DAO接口所在包名,Spring会自动查找其下的类 -->
47 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
48 <property name="basePackage" value="com.projMgr.Dao" />
49 <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
50 </bean>
51
52 <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->
53 <bean id="transactionManager"
54 class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
55 <property name="dataSource" ref="dataSource" />
56 </bean>
57 </beans>
3.2.3、Log4j的配置(log4j.properties)
为了方便调试,一般都会使用日志来输出信息,Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。
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 #文件大小到达指定尺寸的时候产生一个新的文件
11 log4j.appender.File = org.apache.log4j.RollingFileAppender
12 #指定输出目录
13 log4j.appender.File.File = logs/ssm.log
14 #定义文件最大大小
15 log4j.appender.File.MaxFileSize = 10MB
16 # 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志
17 log4j.appender.File.Threshold = ALL
18 log4j.appender.File.layout = org.apache.log4j.PatternLayout
19 log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n
3.2.4、JUnit测试
经过以上步骤(log4j不配也没影响),我们已经完成了Spring和mybatis的整合,这样我们就可以编写一段测试代码来试试是否成功了。
3.2.4.1、创建测试用表
1 DROP TABLE IF EXISTS `user`; 2 3 CREATE TABLE `user` ( 4 5 `id` int(11) NOT NULL AUTO_INCREMENT, 6 7 `user_name` varchar(40) NOT NULL, 8 9 `password` varchar(255) NOT NULL, 10 11 `age` int(4) NOT NULL, 12 13 PRIMARY KEY (`id`) 14 15 ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; 16 17 /*Data for the table `user` */ 18 19 insert into `user`(`id`,`user_name`,`password`,`age`) values (1,'张三','2013',4);
3.2.4.2、利用MyBatis Generator自动创建代码
参考:
http://blog.csdn.net/zhshulin/article/details/23912615
http://www.cnblogs.com/smileberry/p/4145872.html
这个可根据表自动创建实体类、MyBatis映射文件以及DAO接口,复制到项目中。
建立文件夹,所需文件:

generatorConfig.xml文件:
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE generatorConfiguration 3 PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" 4 "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> 5 <generatorConfiguration> 6 <!-- 数据库驱动--> 7 <classPathEntry location="mysql-connector-java-5.1.30.jar"/> 8 <context id="DB2Tables" targetRuntime="MyBatis3"> 9 <commentGenerator> 10 <property name="suppressDate" value="true"/> 11 <!-- 是否去除自动生成的注释 true:是 : false:否 --> 12 <property name="suppressAllComments" value="true"/> 13 </commentGenerator> 14 <!--数据库链接URL,用户名、密码 --> 15 <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/数据库名称" userId="用户名" password="密码"> 16 </jdbcConnection> 17 <javaTypeResolver> 18 <property name="forceBigDecimals" value="false"/> 19 </javaTypeResolver> 20 <!-- 生成模型的包名和位置--> 21 <javaModelGenerator targetPackage="test.model" targetProject="src"> 22 <property name="enableSubPackages" value="true"/> 23 <property name="trimStrings" value="true"/> 24 </javaModelGenerator> 25 <!-- 生成映射文件的包名和位置--> 26 <sqlMapGenerator targetPackage="test.mapping" targetProject="src"> 27 <property name="enableSubPackages" value="true"/> 28 </sqlMapGenerator> 29 <!-- 生成DAO的包名和位置--> 30 <javaClientGenerator type="XMLMAPPER" targetPackage="test.IDao" targetProject="src"> 31 <property name="enableSubPackages" value="true"/> 32 </javaClientGenerator> 33 <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名--> 34 <table tableName="user" domainObjectName="User" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table> 35 </context> 36 </generatorConfiguration>
在mybatis-generator-core-1.3.2文件所在处,按住shift,右键,选择“在此处打开命令窗口”,黏贴一下代码,回车运行。
1 java -jar mybatis-generator-core-1.3.2.jar -configfile generatorConfig.xml -overwrite
运行结果:

生成结果:

复制到项目中,并修改目录、文件名称

3.2.4.3、建立Service接口和实现类
目录结构:

以下是具体代码:
IUserService.java
1 package com.projMgr.service;
2
3 import java.util.List;
4
5 import com.projMgr.pojo.User;
6
7 public interface IUserService {
8 public User getUserById(int userId);
9 }
UserServiceImpl.java
1 package com.projMgr.service;
2
3 import java.util.List;
4
5 import javax.annotation.Resource;
6
7 import org.springframework.stereotype.Service;
8
9 import com.projMgr.Dao.IUserDao;
10 import com.projMgr.pojo.User;
11 import com.projMgr.service.IUserService;
12
13 @Service("userService")
14 public class UserServiceImpl implements IUserService {
15 @Resource
16 private IUserDao userDao;
17 @Override
18 public User getUserById(int userId) {
19 return this.userDao.selectByPrimaryKey(userId);
20 }
21
22 }
3.2.4.4、建立测试类
测试类在src/test/java中建立,下面测试类中注释掉的部分是不使用Spring时,一般情况下的一种测试方法;如果使用了Spring那么就可以使用注解的方式来引入配置文件和类,然后再将service接口对象注入,就可以进行测试了。
如果测试成功,表示Spring和Mybatis已经整合成功了。输出信息使用的是Log4j打印到控制台。

TestMyBatis.java
1 package org.projMgr.testmybatis;
2
3 import javax.annotation.Resource;
4
5 import org.apache.log4j.Logger;
6 //import org.junit.Before;
7 import org.junit.Test;
8 import org.junit.runner.RunWith;
9 //import org.springframework.context.ApplicationContext;
10 //import org.springframework.context.support.ClassPathXmlApplicationContext;
11 import org.springframework.test.context.ContextConfiguration;
12 import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
13
14 import com.alibaba.fastjson.JSON;
15 import com.projMgr.pojo.User;
16 import com.projMgr.service.IUserService;
17
18 @RunWith(SpringJUnit4ClassRunner.class) //��ʾ�̳���SpringJUnit4ClassRunner��
19 @ContextConfiguration(locations = {"classpath:spring-mybatis.xml"})
20
21 public class TestMyBatis {
22 private static Logger logger = Logger.getLogger(TestMyBatis.class);
23 // private ApplicationContext ac = null;
24 @Resource
25 private IUserService userService = null;
26
27 // @Before
28 // public void before() {
29 // ac = new ClassPathXmlApplicationContext("applicationContext.xml");
30 // userService = (IUserService) ac.getBean("userService");
31 // }
32
33 @Test
34 public void test1() {
35 User user = userService.getUserById(1);
36 // System.out.println(user.getUserName());
37 // logger.info("ֵ:"+user.getUserName());
38 logger.info(JSON.toJSONString(user));
39 }
40 }
测试结果:

如果测试成功,则完成Spring和mybatis这两大框架的整合,下面在继续进行SpringMVC的整合。
3.3、整合SpringMVC
上面已经完成了2大框架的整合,SpringMVC的配置文件单独放,然后在web.xml中配置整合。
3.3.1、配置spring-mvc.xml
配置主要是自动扫描控制器,视图模式,注解的启动这三个。
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.projMgr.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 <!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 --> 40 <bean id="multipartResolver" 41 class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> 42 <!-- 默认编码 --> 43 <property name="defaultEncoding" value="utf-8" /> 44 <!-- 文件大小最大值 --> 45 <property name="maxUploadSize" value="10485760000" /> 46 <!-- 内存中的最大值 --> 47 <property name="maxInMemorySize" value="40960" /> 48 </bean> 49 50 </beans>
3.3.2、配置web.xml文件
这里面对spring-mybatis.xml的引入以及配置的spring-mvc的Servlet就是为了完成SSM整合
web.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 3 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 4 xmlns="http://java.sun.com/xml/ns/javaee" 5 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" 6 id="WebApp_ID" version="3.0"> 7 <display-name>Archetype Created Web Application</display-name> 8 <!-- Spring和mybatis的配置文件 --> 9 <context-param> 10 <param-name>contextConfigLocation</param-name> 11 <param-value>classpath:spring-mybatis.xml</param-value> 12 </context-param> 13 14 <!-- 编码过滤器 --> 15 <filter> 16 <filter-name>encodingFilter</filter-name> 17 <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> 18 <async-supported>true</async-supported> 19 <init-param> 20 <param-name>encoding</param-name> 21 <param-value>UTF-8</param-value> 22 </init-param> 23 </filter> 24 <filter-mapping> 25 <filter-name>encodingFilter</filter-name> 26 <url-pattern>/*</url-pattern> 27 </filter-mapping> 28 <!-- Spring监听器 --> 29 <listener> 30 <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 31 </listener> 32 <!-- 防止Spring内存溢出监听器 --> 33 <listener> 34 <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class> 35 </listener> 36 37 <!-- Spring MVC servlet --> 38 <servlet> 39 <servlet-name>SpringMVC</servlet-name> 40 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 41 <init-param> 42 <param-name>contextConfigLocation</param-name> 43 <param-value>classpath:spring-mvc.xml</param-value> 44 </init-param> 45 <load-on-startup>1</load-on-startup> 46 <async-supported>true</async-supported> 47 </servlet> 48 <servlet-mapping> 49 <servlet-name>SpringMVC</servlet-name> 50 <!-- 此处可以可以配置成*.do,对应struts的后缀习惯 --> 51 <url-pattern>/</url-pattern> 52 </servlet-mapping> 53 <welcome-file-list> 54 <welcome-file>/index.jsp</welcome-file> 55 </welcome-file-list> 56 <!-- 配置SESSION超时,单位是分钟 --> 57 <session-config> 58 <session-timeout>30</session-timeout> 59 </session-config> 60 </web-app>
3.3.3、测试
至此已经完成了SSM三大框架的整合了,接下来测试一下,如果成功了即可。
3.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
8 <body>
9 ${user.userName}
10 ${user.password}
11 </body>
12 </html>
3.3.3.2、建立UserController类

UserController.java
1 package com.projMgr.controller;
2
3 import java.util.List;
4
5 import javax.annotation.Resource;
6 import javax.servlet.http.HttpServletRequest;
7
8 //import org.springframework.beans.factory.annotation.Autowired;
9 import org.springframework.stereotype.Controller;
10 import org.springframework.ui.Model;
11 //import org.springframework.ui.Model;
12 import org.springframework.web.bind.annotation.RequestMapping;
13 import com.projMgr.pojo.User;
14 import com.projMgr.service.IUserService;
15
16 @Controller
17 @RequestMapping("/user")
18 public class UserController {
19 @Resource
20 private IUserService userService;
21
22 @RequestMapping("/showUser")
23 public String toIndex(HttpServletRequest request,Model model){
24 int userId = Integer.parseInt(request.getParameter("id"));
25 User user = this.userService.getUserById(userId);
26 model.addAttribute("user", user);
27 return "/showUser";
28 }
29
30
31 }
3.3.3.3、部署项目
tomcat8.0启动,成功日志:(可用于出错对照)
1 二月 23, 2017 2:36:26 下午 org.apache.catalina.core.AprLifecycleListener init
2 信息: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:\Program Files\Java\jre1.8.0_25\bin;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS;C:/Program Files/Java/jre1.8.0_25/bin/server;C:/Program Files/Java/jre1.8.0_25/bin;C:/Program Files/Java/jre1.8.0_25/lib/amd64;D:\developing\thinkgem-jeesite-6c5ea82\doc\maven\maven3\bin;C:\ProgramData\Oracle\Java\javapath;D:\Users\Administrator\bin\Sencha\Cmd\5.1.0.26;C:\Program Files (x86)\AMD APP\bin\x86_64;C:\Program Files (x86)\AMD APP\bin\x86;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\;C:\Program Files\Java\jdk1.8.0_25\bin;C:\Program Files\Java\jdk1.8.0_25\jre\bin;D:\developing\mysql\bin;C:\Program Files (x86)\IVI Foundation\IVI\bin;C:\Program Files\IVI Foundation\IVI\bin;C:\PROGRA~2\IVIFOU~1\VISA\WinNT\Bin;C:\Program Files (x86)\IVI Foundation\VISA\WinNT\Bin\;C:\Program Files\IVI Foundation\VISA\Win64\Bin\;C:\Program Files (x86)\IVI Foundation\VISA\WinNT\Bin;C:\Program Files (x86)\ATI Technologies\ATI.ACE\Core-Static;C:\Program Files\Agilent\IO Libraries Suite\bin;C:\Program Files\IVI Foundation\VISA\Win64\agvisa;C:\Program Files (x86)\Agilent\IO Libraries Suite\bin;C:\Program Files (x86)\IVI Foundation\VISA\WinNT\agvisa;D:\developing\apache-maven-3.2.2\bin;D:\Program Files (x86)\Git\cmd;D:\Program Files (x86)\Git\bin;C:\Program Files\Ant\apache-ant-1.9.7\bin;D:\Program Files\TortoiseSVN\bin;D:\developing\eclipse;;.
3 二月 23, 2017 2:36:26 下午 org.apache.tomcat.util.digester.SetPropertiesRule begin
4 警告: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:projectManagement' did not find a matching property.
5 二月 23, 2017 2:36:26 下午 org.apache.coyote.AbstractProtocol init
6 信息: Initializing ProtocolHandler ["http-nio-89"]
7 二月 23, 2017 2:36:26 下午 org.apache.tomcat.util.net.NioSelectorPool getSharedSelector
8 信息: Using a shared selector for servlet write/read
9 二月 23, 2017 2:36:26 下午 org.apache.coyote.AbstractProtocol init
10 信息: Initializing ProtocolHandler ["ajp-nio-8009"]
11 二月 23, 2017 2:36:26 下午 org.apache.tomcat.util.net.NioSelectorPool getSharedSelector
12 信息: Using a shared selector for servlet write/read
13 二月 23, 2017 2:36:26 下午 org.apache.catalina.startup.Catalina load
14 信息: Initialization processed in 1036 ms
15 二月 23, 2017 2:36:26 下午 org.apache.catalina.core.StandardService startInternal
16 信息: Starting service Catalina
17 二月 23, 2017 2:36:26 下午 org.apache.catalina.core.StandardEngine startInternal
18 信息: Starting Servlet Engine: Apache Tomcat/8.0.9
19 二月 23, 2017 2:36:27 下午 org.apache.catalina.util.SessionIdGenerator createSecureRandom
20 信息: Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [117] milliseconds.
21 二月 23, 2017 2:36:34 下午 org.apache.catalina.core.ApplicationContext log
22 信息: No Spring WebApplicationInitializer types detected on classpath
23 SLF4J: Class path contains multiple SLF4J bindings.
24 SLF4J: Found binding in [jar:file:/D:/developing/eclipse/workspace/ProjectManagement/.metadata/.plugins/org.eclipse.wst.server.core/tmp0/wtpwebapps/projectManagement/WEB-INF/lib/slf4j-log4j12-1.7.6.jar!/org/slf4j/impl/StaticLoggerBinder.class]
25 SLF4J: Found binding in [jar:file:/D:/developing/eclipse/workspace/ProjectManagement/.metadata/.plugins/org.eclipse.wst.server.core/tmp0/wtpwebapps/projectManagement/WEB-INF/lib/slf4j-log4j12-1.7.7.jar!/org/slf4j/impl/StaticLoggerBinder.class]
26 SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
27 SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
28 二月 23, 2017 2:36:35 下午 org.apache.catalina.core.ApplicationContext log
29 信息: Initializing Spring root WebApplicationContext
30 [org.springframework.web.context.ContextLoader] - Root WebApplicationContext: initialization started
31 [org.springframework.web.context.support.XmlWebApplicationContext] - Refreshing Root WebApplicationContext: startup date [Thu Feb 23 14:36:35 CST 2017]; root of context hierarchy
32 [org.springframework.beans.factory.xml.XmlBeanDefinitionReader] - Loading XML bean definitions from class path resource [spring-mybatis.xml]
33 [org.springframework.beans.factory.config.PropertyPlaceholderConfigurer] - Loading properties file from class path resource [jdbc.properties]
34 [org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor] - JSR-330 'javax.inject.Inject' annotation found and supported for autowiring
35 [org.springframework.web.context.ContextLoader] - Root WebApplicationContext: initialization completed in 2081 ms
36 二月 23, 2017 2:36:37 下午 org.apache.catalina.core.ApplicationContext log
37 信息: Initializing Spring FrameworkServlet 'SpringMVC'
38 [org.springframework.web.servlet.DispatcherServlet] - FrameworkServlet 'SpringMVC': initialization started
39 [org.springframework.web.context.support.XmlWebApplicationContext] - Refreshing WebApplicationContext for namespace 'SpringMVC-servlet': startup date [Thu Feb 23 14:36:37 CST 2017]; parent: Root WebApplicationContext
40 [org.springframework.beans.factory.xml.XmlBeanDefinitionReader] - Loading XML bean definitions from class path resource [spring-mvc.xml]
41 [org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor] - JSR-330 'javax.inject.Inject' annotation found and supported for autowiring
42 [org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping] - Mapped URL path [/user/showUser] onto handler 'userController'
43 [org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping] - Mapped URL path [/user/showUser.*] onto handler 'userController'
44 [org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping] - Mapped URL path [/user/showUser/] onto handler 'userController'
45 [org.springframework.web.servlet.DispatcherServlet] - FrameworkServlet 'SpringMVC': initialization completed in 1254 ms
46 二月 23, 2017 2:36:38 下午 org.apache.coyote.AbstractProtocol start
47 信息: Starting ProtocolHandler ["http-nio-89"]
48 二月 23, 2017 2:36:38 下午 org.apache.coyote.AbstractProtocol start
49 信息: Starting ProtocolHandler ["ajp-nio-8009"]
50 二月 23, 2017 2:36:38 下午 org.apache.catalina.startup.Catalina start
51 信息: Server startup in 12041 ms
输入地址:localhost:端口号/项目名称/user/showUser?id=1
如图,这样,基本的框架就搭建完成了!

4,过程错误
4.1情况1:
Project configuration is not up-to-date with pom.xml. Run Maven->Update Project or use Quick Fix.
在Problems View的出错提示右键选Quick Fix,再按提示确定就OK.或者,右键项目->Maven->Update Project
4.2情况2:
JavaServer Faces 2.2 can not be installed : One or more constraints have not been satisfied.
JavaServer Faces 2.2 requires Dynamic Web Module 2.5 or newer.
先改web.xmlwebapp节点:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
</web-app>
然后关闭Eclipse,改项目下的.settings\org.eclipse.wst.common.project.facet.core.xml.将版本改成为3.1,将成后是<installed facet="jst.web" version="3.1"/>,再启动Eclipse.最后出现上面的情况1,按上面更新下配置就OK.
4.3情况3:
情况3:
JDK版本设置:
pom.xml配置
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
来源:https://www.cnblogs.com/sucia-panda/p/6432845.html