Spring+SpringMVC+MyBatis框架搭建

搭建框架所用版本

Spring : 4.0.2.RELEASE

Mybatis : 3.2.6

Spring MVC : 4.0.2.RELEASE

1. Eclipse创建Maven工程

2. 在创建的Maven 工程中将目录结构补充完整

Spring+SpringMVC+MyBatis框架搭建_第1张图片 

3. Pom文件中依赖搭建框架所需要的包

<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>testSSM</groupId>

<artifactId>testSSM</artifactId>

<version>0.0.1-SNAPSHOT</version>

 

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

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>4.12</version>

<!-- 表示开发的时候引入,发布的时候不会加载此包 -->

<scope>test</scope>

</dependency>

<!-- 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>

 

<!-- mybatis 自動生成代碼包 -->

<dependency>

<groupId>org.mybatis.generator</groupId>

<artifactId>mybatis-generator-core</artifactId>

<version>1.3.2</version>

</dependency>

 

<!-- 导入java ee jar 包 -->

<dependency>

<groupId>javax</groupId>

<artifactId>javaee-api</artifactId>

<version>7.0</version>

</dependency>

<!-- 导入Mysql数据库链接jar包 -->

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<version>5.1.38</version>

</dependency>

<!-- 导入dbcp的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>

<!-- 日志文件管理包 -->

<!-- log start -->

<dependency>

<groupId>log4j</groupId>

<artifactId>log4j</artifactId>

<version>1.2.12</version>

</dependency>

 

<!-- 格式化对象,方便输出日志 -->

<dependency>

<groupId>com.alibaba</groupId>

<artifactId>fastjson</artifactId>

<version>1.2.7</version>

</dependency>

 

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>slf4j-api</artifactId>

<version>1.7.16</version>

</dependency>

 

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>slf4j-log4j12</artifactId>

<version>1.7.16</version>

</dependency>

<!-- log end -->

<!-- 映入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>

 

</dependencies>

 

</project>

4. 配置连接数据库所需要的参数jdbc.properties

driver=com.mysql.jdbc.Driver

#自身数据库连接方式:路径/数据库名

url=jdbc:mysql://localhost:3306/testmybatis

#数据库用户

username=root

#数据库密码

password=930325

#定义初始化连接数

initialSize=0

#定义最大连接数

maxActive=20

#定义最大空闲  

maxIdle=20

#定义最小空闲  

minIdle=1

#定义最长等待时间  

maxWait=60000

5. 配置log4j.properties

#定义log输出级别

log4j.rootLogger=INFO,Console,File

#定义日志输出到控制台

log4j.appender.Console=org.apache.log4j.ConsoleAppender

log4j.appender.Console.Target=System.out

#指定日志输出格式

log4j.appender.Console.layout = org.apache.log4j.PatternLayout

#指定具体格式

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

#输出警告以上的日志

log4j.appender.File.Threshold = WARNING

log4j.appender.File.layout = org.apache.log4j.PatternLayout  

log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n 

6. Spring-mybatis.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">

<!-- 自动扫描 -->

<!-- base-package根据自身项目不同而改动 -->

    <context:component-scan base-package="com.scymore.testMybatis" />

    <!-- 引入配置文件 -->

    <bean id="propertyConfigurer"

      class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

<!-- 前面配置的jdbc.properties文件,为连接数据库提供参数 -->

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

        <!-- 扫描*mapper.xml文件 -->

        <property name="mapperLocations" value="classpath:com/scymore/testMybatis/mapping/*.xml"></property>

    </bean>

 

    <!-- DAO接口所在包名,Spring会自动查找其下的类 -->

    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">

        <property name="basePackage" value="com.scymore.testMybatis.dao" />

        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>

    </bean>

 

    <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->

    <bean id="transactionManager"

        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

        <property name="dataSource" ref="dataSource" />

    </bean>

 

</beans>

7. 利用myBatis 自动生成代码(生成的mapper.xml文件中namespace可能会出错,生成后最好检查一下)

a) 项目根目录创建generatorConfig.xml文件(,文件名随意,其中连接数据库的参数,想要生成代码的路径要进行修改,但是时在项目中)

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

<!DOCTYPE generatorConfiguration    

  PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"    

  "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">    

<generatorConfiguration>    

<!-- 数据库驱动-->    

    <classPathEntry  location="mysql-connector-java-5.1.38.jar"/>    

    <context id="DB2Tables"  targetRuntime="MyBatis3">    

        <commentGenerator>    

            <property name="suppressDate" value="true"/>    

            <!-- 是否去除自动生成的注释 true:是 : false:否 -->    

            <property name="suppressAllComments" value="true"/>    

        </commentGenerator>    

        <!--数据库链接URL,用户名、密码 -->    

        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost/testmybatis" userId="root" password="930325">    

        </jdbcConnection>    

        <javaTypeResolver>    

            <property name="forceBigDecimals" value="false"/>    

        </javaTypeResolver>    

        <!-- 生成模型的包名和位置-->    

        <javaModelGenerator targetPackage="test.java.domain" targetProject="src">    

            <property name="enableSubPackages" value="true"/>    

            <property name="trimStrings" value="true"/>    

        </javaModelGenerator>    

        <!-- 生成映射文件的包名和位置-->    

        <sqlMapGenerator targetPackage="test.java.mapping" targetProject="src">    

            <property name="enableSubPackages" value="true"/>    

        </sqlMapGenerator>    

        <!-- 生成DAO的包名和位置-->    

        <javaClientGenerator type="XMLMAPPER" targetPackage="test.java.dao" targetProject="src">    

            <property name="enableSubPackages" value="true"/>    

        </javaClientGenerator>    

        <!-- 要生成的表 tableName是数据库中的表名或视图名 domainObjectName是实体类名-->    

        <table tableName="person" domainObjectName="Person" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>  

    </context>    

</generatorConfiguration>

b) 将自动生成所需要的三个jar包复制到项目根目录

 

c) 控制台进入项目根目录

d) 执行命令

java -jar mybatis-generator-core-1.3.2.jar -configfile generatorConfig.xml -overwrite

e) 如果直接出现MyBatis Generator finished successfully,恭喜,你运气好,直接成功,不然就重新看看generatorConfig.xml中是否还有什么地方没有填对

f) 我的是生成在test下面的,所以需要复制到正常的java目录下,你们如果直接生成在正常项目下也可以

8. 测试springmybatis的配置是否正确

a) 创建测试类

b) 测试代码

//继承了SpringJUnit4ClassRunner类

@RunWith(SpringJUnit4ClassRunner.class)    

@ContextConfiguration(locations = {"classpath:spring-mybatis.xml"})  

  

public class TestMyBatis {  

 

    @Resource   

    private PersonService personService = new PersonServiceImpl();  

  

    @Test   

    public void test1() {  

        Person person = personService.selectByPrimaryKey(1);

        System.out.println(person.getName());  

    }  

9. 运行测试类

如果前面步骤全部正确

运行结果(我的数据库只有这个,嘿嘿):

 

10. Ok,springmybatis配置成功了,然后就是Spring MVC

11. 创建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="com.scymore.testMybatis.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的映射 -->

<bean

class="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="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>

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

<!-- Spring MVC servlet -->

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

13. Ok,基本完成,后面的还没写.

 

 更详细的请参照 http://blog.csdn.net/gebitan505/article/details/44455235,我也是根据这操作后写的.


你可能感兴趣的:(Spring+SpringMVC+MyBatis框架搭建)