整合ssm

来源:互联网 发布:庞氏骗局 知乎 编辑:程序博客网 时间:2024/06/05 03:04

SSM框架搭建

以前在使用ssm框架的时候,都是使用我们项目经理搭建好的,后来用着方便了,就想着自己也搭建一个试试,然后就自己百度下,搭建了一个,下面自己做个记录吧,可能和别人的搭建过程有重合的地方,毕竟技术都差不多一个样。

在这里说下我创建使用的三个框架的版本号;

Spring 4.0.2 RELEASE

 Spring MVC 4.0.2 RELEASE

 MyBatis 3.2.6

一 创建一个Maven项目

创建一个Maven项目,如何创建Maven项目或者Maven安装具体见我另一篇博客。

具体结构如下:

1,  在Pom.xml文件中引入所需要的Jar包,具体代码如下:

<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/maven-v4_0_0.xsd">  <modelVersion>4.0.0</modelVersion>  <groupId>MavenSsmOne</groupId>  <artifactId>SSM</artifactId>  <packaging>war</packaging>  <version>0.0.1-SNAPSHOT</version>  <name>SSM Maven Webapp</name>  <url>http://maven.apache.org</url>    <properties>  <!-- Spring版本号 -->  <spring.version>4.0.2.RELEASE</spring.version>  <!-- mybatis版本号 -->  <mybatis.version>3.2.6</mybatis.version>  <!-- Log4j日志文件管理包版本 -->  <slf4j.version>1.7.7</slf4j.version>  <log4j.version>1.2.17</log4j.version>  </properties>    <dependencies>  <!-- spring 核心包 -->    <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-core</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-oxm</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>org.springframework</groupId>    <artifactId>spring-webmvc</artifactId>    <version>${spring.version}</version>    </dependency>    <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-aop</artifactId>    <version>${spring.version}</version>    </dependency>    <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-context-support</artifactId>    <version>${spring.version}</version>    </dependency>    <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-test</artifactId>    <version>${spring.version}</version>    </dependency>        <!-- mybatis核心包 -->    <dependency>    <groupId>org.mybatis</groupId>    <artifactId>mybatis</artifactId>    <version>${mybatis.version}</version>    </dependency>        <!-- mybatis\spring包 -->    <dependency>    <groupId>org.mybatis</groupId>    <artifactId>mybatis-spring</artifactId>    <version>1.2.2</version>    </dependency>        <!-- 导入mysql数据库连接包 -->    <dependency>    <groupId>mysql</groupId>    <artifactId>mysql-connector-java</artifactId>    <version>5.1.30</version>    </dependency>    <!-- 导入jdbc的jar包,用来在applicationContext.xml中配置数据库 -->    <dependency>    <groupId>commons-dbcp</groupId>    <artifactId>commons-dbcp</artifactId>    <version>1.2.2</version>    </dependency>        <!-- Jstl标签类 -->    <dependency>    <groupId>jstl</groupId>    <artifactId>jstl</artifactId>    <version>1.2</version>    </dependency>        <!-- 日志文件管理包 -->    <dependency>    <groupId>log4j</groupId>    <artifactId>log4j</artifactId>    <version>${log4j.version}</version>    </dependency>        <!-- 格式化对象,方便日志输出 -->    <dependency>    <groupId>com.alibaba</groupId>    <artifactId>fastjson</artifactId>    <version>1.1.41</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>        <!-- 映入json -->    <dependency>    <groupId>org.codehaus.jackson</groupId>    <artifactId>jackson-mapper-asl</artifactId>    <version>1.9.13</version>    </dependency>        <!-- 上传组件包 -->    <dependency>    <groupId>commons-fileupload</groupId>    <artifactId>commons-fileupload</artifactId>    <version>1.3.1</version>    </dependency>    <dependency>    <groupId>commons-io</groupId>    <artifactId>commons-io</artifactId>    <version>2.4</version>    </dependency>    <dependency>    <groupId>commons-codec</groupId>    <artifactId>commons-codec</artifactId>    <version>1.9</version>    </dependency>        <!-- 表示开发的时候引入,发布的时候不会加载此包 -->    <dependency>      <groupId>junit</groupId>      <artifactId>junit</artifactId>      <version>3.8.1</version>      <scope>test</scope>    </dependency>        <!-- 导入java ee jar包 -->    <dependency> <groupId>Javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version>   </dependency>  </dependencies>    <build>    <finalName>SSM</finalName>  </build></project>

二 spring和Mybatis的整合

首先展示下,我的目录结构:

(1)创建jdbc.properties

driver=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf-8username=rootpassword=root#初始化连接大小initialSize=0#连接池最大数量maxActive=20#连接池最大空闲maxIdle=20#连接池最小空闲minIdle=1#获取连接最大等待时间maxWait=60000

(2)建立Spring-Mybatis.xml的配置文件

这个文件就是用来完成spring和mybatis的整合的。这里面也没多少行配置,主要的就是自动扫描,自动注入,配置数据库。具体见文件的注释。

<?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:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beans                          http://www.springframework.org/schema/beans/spring-beans-3.1.xsd                          http://www.springframework.org/schema/context                          http://www.springframework.org/schema/context/spring-context-3.1.xsd                          http://www.springframework.org/schema/mvc                          http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"><!-- 自动扫描,这个地方扫描的是自己service包的路径和名称,在配置的时候,需要更换成自己包名和路径 --><context:component-scan base-package="userServiceInterfaceImp" /><!-- 引入配置文件 --><bean id="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="location" value="classpath:jdbc.properties" /></bean><bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"destroy-method="close"><property name="driverClassName" value="${driver}" /><property name="url" value="${url}" /><property name="username" value="${username}" /><property name="password" value="${password}" /><!-- 初始化连接大小 --><property name="initialSize" value="${initialSize}"></property><!-- 连接池最大数量 --><property name="maxActive" value="${maxActive}"></property><!-- 连接池最大空闲 --><property name="maxIdle" value="${maxIdle}"></property><!-- 连接池最小空闲 --><property name="minIdle" value="${minIdle}"></property><!-- 获取连接最大等待时间 --><property name="maxWait" value="${maxWait}"></property></bean><!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource" /><!-- 自动扫描mapping.xml文件在此处加上自己mapping.xml文件的路径和名称 --><property name="mapperLocations" value="classpath:userMapping/*.xml"></property></bean><!-- DAO接口所在包名,Spring会自动查找其下的类 --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="userDao" /><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/></bean> <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --><bean id="transactionManager"class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource" /></bean></beans>

(3)Log4j.properties

 

为了方便调试,一般都会使用日志来输出信息,Log4jApache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。Log4j的配置比较简单,而是通用,具体详解,我的另一篇博客里面有。Log4j详解

#定义LOG输出级别log4j.rootLogger=INFO,Console,File#定义日志输出目的地为控制台log4j.appender.Console=org.apache.log4j.ConsoleAppenderlog4j.appender.Console.Target=System.out#可以灵活地指定日志输出格式,下面一行是指定具体的格式log4j.appender.Console.layout = org.apache.log4j.PatternLayoutlog4j.appender.Console.layout.ConversionPattern=[%c] - %m%n#文件大小到达指定尺寸的时候产生一个新的文件log4j.appender.File = org.apache.log4j.RollingFileAppender#指定输出目录log4j.appender.File.File = logs/ssm.log#定义文件最大大小log4j.appender.File.MaxFileSize = 10MB# 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志log4j.appender.File.Threshold = ALLlog4j.appender.File.layout = org.apache.log4j.PatternLayoutlog4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n

(4)JUnit测试

1,  己在数据库中创建一个数据库和表,具体如下图:

2,使用MyBatis Generator自动创建代码,然后复制粘贴到自己的项目里面即可。

3,创建Service接口和实现类:

结构图如下:


接口:package userServiceInterface;import userPojo.User;public interface userServerInte {public User getUserById(int userId);}实现类:package userServiceInterfaceImp;import javax.annotation.Resource;import org.springframework.stereotype.Service;import userDao.UserMapper;import userPojo.User;import userServiceInterface.userServerInte;@Service("userService")public class userServiceInteImp implements userServerInte{@Resourceprivate UserMapper userDao; public User getUserById(int userId) {Integer userId1 = 1;return this.userDao.selectByPrimaryKey(userId1);}}

4,建立测试类:

结构如下:


内容如下:package test;import javax.annotation.Resource;import org.apache.log4j.Logger;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.test.context.ContextConfiguration;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import userPojo.User;import userServiceInterface.userServerInte;import com.alibaba.fastjson.JSON;@RunWith(SpringJUnit4ClassRunner.class)//表示继承了SpringJUnit4ClassRunner类@ContextConfiguration(locations = {"classpath:spring-mybatis.xml"})public class testMybatis {private static Logger logger = Logger.getLogger(testMybatis.class);@Resourceprivate userServerInte useSer = null;@Testpublic void test1() {User user = useSer.getUserById(1);System.out.println(user.getName());logger.info(JSON.toJSONString(user));}}

结果如图:

如果没有出现结果,你可以在某个地方配置错误,然后自己慢慢调试吧,尤其在Spring-Mybatis.xml文件中,如果那个自动扫描和扫描.xml文件的时候,配置成自己的。

三 整合SpringMvc

(1)配置Spring-mvc.xml

创建Spring-mvc.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:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beans                          http://www.springframework.org/schema/beans/spring-beans-3.1.xsd                          http://www.springframework.org/schema/context                          http://www.springframework.org/schema/context/spring-context-3.1.xsd                          http://www.springframework.org/schema/mvc                          http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"><!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 --><context:component-scan base-package="controller" /><!--避免IE执行AJAX时,返回JSON出现下载文件 --><bean id="mappingJacksonHttpMessageConverter"class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"><property name="supportedMediaTypes"><list><value>text/html;charset=UTF-8</value></list></property></bean><!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 --><beanclass="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"><property name="messageConverters"><list><ref bean="mappingJacksonHttpMessageConverter" /><!-- JSON转换器 --></list></property></bean><!-- 定义跳转的文件的前后缀 ,视图模式配置--><bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 --><!-- <property name="prefix" value="/WEB-INF/jsp/" /> --><property name="prefix" value="/WEB-INF/jsp/" /><property name="suffix" value=".jsp" /></bean><!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 --><bean id="multipartResolver"          class="org.springframework.web.multipart.commons.CommonsMultipartResolver">          <!-- 默认编码 -->        <property name="defaultEncoding" value="utf-8" />          <!-- 文件大小最大值 -->        <property name="maxUploadSize" value="10485760000" />          <!-- 内存中的最大值 -->        <property name="maxInMemorySize" value="40960" />      </bean> </beans>

(2)配置web.xml文件

<?xml version="1.0" encoding="utf-8"?><web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://java.sun.com/xml/ns/javaee"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"version="3.0"><display-name>Archetype Created Web Application</display-name><!-- Spring和mybatis配置文件 --><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring-mybatis.xml</param-value></context-param><!-- 编码过滤器 --><filter><filter-name>encodingFilter</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><async-supported>true</async-supported><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping><!-- spring监听器 --><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><!-- 防止spring内存溢出监听器 --><listener><listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class></listener><!-- Sping Mvc serlet --><servlet><servlet-name>SpringMvc</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring-mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup><async-supported>true</async-supported></servlet><servlet-mapping><servlet-name>SpringMvc</servlet-name><!-- 此处可以可以配置成*.do,对应struts的后缀习惯  --><url-pattern>/</url-pattern></servlet-mapping><welcome-file-list><welcome-file>/index.jsp</welcome-file></welcome-file-list></web-app>

3)测试

1,在WEB-INF文件中,创建Jsp文件夹,然后创建showUser.jsp,在这个页面中输出从数据库中查找的数据:

<%@ page language="java"contentType="text/html; charset=utf-8"    pageEncoding="utf-8"%><%@ taglib prefix="form"uri="http://www.springframework.org/tags/form"%><!DOCTYPE html PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type"content="text/html; charset=utf-8"><title>测试</title></head><body><form:form id="inputForm"modelAttribute="user" action=" "method="post">    name; <form:input path="name" htmlEscape="false"class="hover outsideProcessPlant"/>    sex:<form:input path="sex" htmlEscape="false"class="hover outsideProcessPlant"/>    id :<form:input path="id" htmlEscape="false"class="hover outsideProcessPlant"/></form:form></body></html>

2,创建UserController.java类

package controller; import javax.annotation.Resource;import javax.servlet.http.HttpServletRequest;import org.springframework.stereotype.Controller;import org.springframework.ui.Model;import org.springframework.web.bind.annotation.RequestMapping;import userPojo.User;import userServiceInterface.userServerInte;@Controller@RequestMapping("/user")publicclassUserController {    @Resource    private userServerInte userService;    @RequestMapping("/showUser")    public StringtoIndex(HttpServletRequest request,Model model){      int userId = Integer.parseInt(request.getParameter("id"));       Useruser = this.userService.getUserById(userId);       model.addAttribute("user", user);       return"showUser";    }}

(4)部署项目

http://localhost:8989/SSM/user/showUser?id=1


源码以及文档下载