后台学习一---spring+maven+mybatis+mysql+junit整合

1.工具/原料

• apache-tomcat-7.0.63 http://download.csdn.net/detail/lxfhahaha/9778163
• apache-maven-3.3.3 http://download.csdn.net/detail/lxfhahaha/9778158
• MySQL Server 5.0 http://download.csdn.net/detail/lxfhahaha/9763675
• Navicat for MySQL http://download.csdn.net/download/lxfhahaha/10010242
• jdk1.8.0_73
• IntelliJ IDEA 2016.3.4

2.前言

SSM ( Spring、SpringMVC 和Mybatis )框架集由Spring、SpringMVC、MyBatis三个开源框架整合而成,常作为数据源较简单的web项目的框架,现在我们用IDEA来做开发工具,选择mysql当数据库,从无到有,来创建一个简单的基于ssm框架的maven web项目——hello world。

3.步骤

1).准备工作

1.1 mysql数据库安装

http://blog.csdn.net/lxfhahaha/article/details/56847353

1.2 tomcat安装

把tomcat下过来后,解压在本地,修改server.xml文件
增加URIEncoding="utf-8"
后台学习一---spring+maven+mybatis+mysql+junit整合_第1张图片

1.3 maven安装

把maven下过来之后,解压在本地,修改settings.xml
对应的是maven的放置目录
后台学习一---spring+maven+mybatis+mysql+junit整合_第2张图片

1.4 jdk安装

1.4.1 jdk安装

1.4.2 jdk环境变量配置

这个网上很多,就不累述了

1.5 idea安装

2).创建maven web项目

后台学习一---spring+maven+mybatis+mysql+junit整合_第3张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第4张图片
点击Next,填写GroupId、ArtifactId(groupId一般是域名的反写,也作为项目中类的包名,artifactId是工程名,也就是根文件夹名)
后台学习一---spring+maven+mybatis+mysql+junit整合_第5张图片
然后next,选择本地maven的位置
后台学习一---spring+maven+mybatis+mysql+junit整合_第6张图片
继续next,选择项目保存的位置
后台学习一---spring+maven+mybatis+mysql+junit整合_第7张图片
点击finish,他会自动生成maven骨架,下载所需要的jar包,第一次创建所需要的时间可能比较长,以后就快了,等待其完成。
创建完后的项目结构如图

(Tips:这里要注意的是,如果idea生成maven速度很慢很慢,一直在下载东西,name可以试试看以下方法:用游览器打开http://repo1.maven.org/maven2/archetype-catalog.xml,打开这个东西速度很慢很慢。。看来生成慢也不是没有道理的了,把这个东西打开后,全部复制到本地为archetype-catalog.xml,放在复制到如下目录:
.m2\repository\org\apache\maven\archetype\archetype-catalog\2.4目录下,没有就新建
后台学习一---spring+maven+mybatis+mysql+junit整合_第8张图片
然后到idea的file-setting里面添加参数,-DarchetypeCatalog=local,以替换网络上的catalog.xml。
后台学习一---spring+maven+mybatis+mysql+junit整合_第9张图片
然后重新来一遍,速度应该就快多了)

2017-2-27 20:25:57
最近比较懒,,理理看思路。。上回讲到哪了,,继续继续。。

新建完之后,是下面这样的,大家可以看看目录结构
后台学习一---spring+maven+mybatis+mysql+junit整合_第10张图片

  1. .idea文件夹和helloworld.iml是idea的一些配置文件,我们不用管,就算删了也没事,当然删了,重新打开项目,就得重新配置了
  2. src文件夹就是我们放项目代码的地方
  3. pom.xml是maven的配置文件,我们需要什么jar包,都可以在里面添加依赖,然后maven就会自己帮我们下到本地仓库里面

然后自己新建几个文件夹,src下新建一个test,用来放测试文件,main下新建一个java,用来放java文件,建好后是这样的
后台学习一---spring+maven+mybatis+mysql+junit整合_第11张图片
接着,执行如下操作:
1. 在main的java文件夹上,鼠标右键,找到 make directory as,选择Sources root
2. 在main的resources文件夹上,鼠标右键,找到make directory as,选择Resources root
3. 在test的java文件夹上,鼠标右键,找到make directory as,选择Test Sources root
4. 在test的resources文件夹上,鼠标右键,找到make directory as,选择Test Resources root

继续修改目录结构,增加一些文件夹及文件,这些都是等一下要用的到的
1. src->main->java下新建package com,再新建package springmvc,这两个对应我们刚开始的groupid
2. springmvc包下新建四个包,controller包用来放前台url映射文件,dao用来放与数据库的接口文件,entity用来放实体类文件,service用来放自己定义的接口
3. applicationContext.xml是spring配置文件
4. sqlmap文件夹里面放实体与数据库的映射文件
5. generator.xml和generator.properties是mybatis的配置文件
6. jdbc.properties是数据库相关信息
7. log4j.properties是日志配置文件
8. webapp下新建css、images等文件,用来放前端资源
9. web-inf下新建views文件件,jsp文件就放这里面了
修改好后的目录结构是这样的
后台学习一---spring+maven+mybatis+mysql+junit整合_第12张图片

3).项目配置文件

1. 配置pom.xml文件,maven引入jar包

   为了方便后面说的时候不需要引入JAR包,我这里直接给出所有需要的JAR包,这都是基本的JAR包,每个包的是干什么的都有注释,就不再多说了。 
   **pom.xml**
   (Ps:如果哪里显示红色报错,就将光标移到那一行,然后键入alt+enter,选择update)
   <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.0modelVersion>
    <groupId>com.springmvcgroupId>
  <artifactId>helloworldartifactId>
  <packaging>warpackaging>
  <version>1.0-SNAPSHOTversion>
  <name>helloworld Maven Webappname>
  <url>http://maven.apache.orgurl>
    <properties>
        
        <spring.version>4.2.5.RELEASEspring.version>
        
        <mybatis.version>3.2.4mybatis.version>
        
        <slf4j.version>1.6.6slf4j.version>
        <log4j.version>1.2.12log4j.version>
    properties>
    <dependencies>
        
        
        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-coreartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-webartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-oxmartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-txartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-jdbcartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-webmvcartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-aopartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-context-supportartifactId>
            <version>${spring.version}version>
        dependency>

        <dependency>
            <groupId>org.springframeworkgroupId>
            <artifactId>spring-testartifactId>
            <version>${spring.version}version>
        dependency>
        

        
        <dependency>
            <groupId>org.mybatisgroupId>
            <artifactId>mybatisartifactId>
            <version>${mybatis.version}version>
        dependency>
        
        <dependency>
            <groupId>org.mybatisgroupId>
            <artifactId>mybatis-springartifactId>
            <version>1.2.2version>
        dependency>
        
        <dependency>
            <groupId>mysqlgroupId>
            <artifactId>mysql-connector-javaartifactId>
            <version>5.1.29version>
        dependency>
        
        <dependency>
            <groupId>junitgroupId>
            <artifactId>junitartifactId>
            <version>4.11version>
            <scope>testscope>
        dependency>
        
        <dependency>
            <groupId>javax.servletgroupId>
            <artifactId>jstlartifactId>
            <version>1.2version>
        dependency>
        <dependency>
            <groupId>javax.servlet.jspgroupId>
            <artifactId>jsp-apiartifactId>
            <version>2.2.1-b03version>
            <scope>providedscope>
        dependency>

        
        <dependency>
            <groupId>javax.servletgroupId>
            <artifactId>servlet-apiartifactId>
            <version>2.5version>
            <scope>providedscope>
        dependency>
        
        <dependency>
            <groupId>com.fasterxml.jackson.coregroupId>
            <artifactId>jackson-coreartifactId>
            <version>2.7.1version>
        dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.coregroupId>
            <artifactId>jackson-annotationsartifactId>
            <version>2.7.1version>
        dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.coregroupId>
            <artifactId>jackson-databindartifactId>
            <version>2.7.1version>
        dependency>
        <dependency>
            <groupId>net.sf.json-libgroupId>
            <artifactId>json-libartifactId>
            <version>2.4version>
            <classifier>jdk15classifier>
        dependency>
        
        <dependency>
            <groupId>commons-langgroupId>
            <artifactId>commons-langartifactId>
            <version>2.4version>
        dependency>
        <dependency>
            <groupId>commons-logginggroupId>
            <artifactId>commons-loggingartifactId>
            <version>1.1version>
        dependency>
        <dependency>
            <groupId>commons-poolgroupId>
            <artifactId>commons-poolartifactId>
            <version>1.5.6version>
        dependency>
        <dependency>
            <groupId>commons-dbcpgroupId>
            <artifactId>commons-dbcpartifactId>
            <version>1.4version>
        dependency>
        <dependency>
            <groupId>commons-beanutilsgroupId>
            <artifactId>commons-beanutilsartifactId>
            <version>1.8.3version>
        dependency>
        <dependency>
            <groupId>commons-httpclientgroupId>
            <artifactId>commons-httpclientartifactId>
            <version>3.1version>
        dependency>
        <dependency>
            <groupId>commons-collectionsgroupId>
            <artifactId>commons-collectionsartifactId>
            <version>3.1version>
        dependency>
        <dependency>
            <groupId>commons-codecgroupId>
            <artifactId>commons-codecartifactId>
            <version>1.9version>
        dependency>
        <dependency>
            <groupId>javax.annotationgroupId>
            <artifactId>jsr250-apiartifactId>
            <version>1.0version>
        dependency>

        <dependency>
            <groupId>net.sf.ezmorphgroupId>
            <artifactId>ezmorphartifactId>
            <version>1.0.6version>
        dependency>
        <dependency>
            <groupId>javax.activationgroupId>
            <artifactId>activationartifactId>
            <version>1.1version>
        dependency>
        <dependency>
            <groupId>taglibsgroupId>
            <artifactId>standardartifactId>
            <version>1.1.2version>
        dependency>
        
        
        <dependency>
            <groupId>log4jgroupId>
            <artifactId>log4jartifactId>
            <version>${log4j.version}version>
        dependency>
        <dependency>
            <groupId>org.slf4jgroupId>
            <artifactId>slf4j-apiartifactId>
            <version>${slf4j.version}version>
        dependency>
        <dependency>
            <groupId>org.slf4jgroupId>
            <artifactId>slf4j-log4j12artifactId>
            <version>${slf4j.version}version>
        dependency>
        
    dependencies>
    <build>
        <finalName>helloworldfinalName>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generatorgroupId>
                <artifactId>mybatis-generator-maven-pluginartifactId>
                <version>1.3.2version>
                <configuration>
                    
                    <verbose>trueverbose>
                    
                    <overwrite>trueoverwrite>
                configuration>
            plugin>
        plugins>
    build>

project>

2.配置jdbc

jdbc.properties (记得输入自己数据库的密码)

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/example?useUnicode=true&characterEncoding=utf-8
username=root
#下面输入自己数据库的密码
password=************************************************
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000

3. spring配置

applicationContext.xml

(Tips:这里面有些地方是要修改的,com.springmvc,你自己的项目的话,换成你自己的就行)


<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:beans="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd" >

    
    <context:component-scan base-package="com.springmvc"/>
    <mvc:annotation-driven />
    
    
    <mvc:resources location="/images/" mapping="/images/**"/>
    <mvc:resources location="/css/" mapping="/css/**"/>
    <mvc:resources location="/styles/" mapping="/styles/**"/>
    <mvc:resources location="/js/" mapping="/js/**"/>

    
    
    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
        <property name="messageConverters">
            <list>
                <ref bean="mappingJacksonHttpMessageConverter"/>
            list>
        property>
    bean>

    <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
        <property name="supportedMediaTypes">
            <list>
                <value>application/json;charset=UTF-8value>
            list>
        property>
    bean>





    
    
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
        <property name="prefix" value="/WEB-INF/views/" />
        <property name="suffix" value=".jsp" />
    bean>




    

    
    
    <bean id = "propertyConfigurer" class = "org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <list>
                <value>classpath:jdbc.propertiesvalue>
            list>
        property>

    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="1"/>
        <property name="maxActive" value="100"/>
        <property name="maxIdle" value="5"/>
        <property name="maxWait" value="80000"/>
    bean>


    
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    bean>


    
    <mvc:interceptors>
        
        <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />
    mvc:interceptors>
    
    <mvc:view-controller path="/" view-name="redirect:/" />


beans>

4. log4j配置

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

log4j.properties

### set log levels ###
log4j.rootLogger = INFO,D

###输出到控制台###
log4j.logger.toConsole=debug,stdout
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout


log4j.appender.stdout.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n

### 输出到日志文件 ###
## 其中File 可以采用绝对路径 亦可以采用相对路径 catalina.home 是tomcat目录 如果没有logs文件夹 将会报错 ##
## 更加倾向于将日志文件放在 tomcat的日志目录下${catalina.home}/logs/salesmanb2bError.log ##
## 绝对路径如:e:/salesmanb2bError.log ##
log4j.logger.daily=INFO,D
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = ${catalina.home}/logs/helloworld/helloworld.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = INFO
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n


##log4j.logger.org.apache.ibatis=debug,stdout
##log4j.logger.java.sql=debug,stdout

2017年2月27日22:31:23

今天就到这了,未完待续~

5. web.xml配置

web.xml


<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>helloworlddisplay-name>
  
  <filter>
    <filter-name>encodingFilterfilter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilterfilter-class>
    <init-param>
      <param-name>encodingparam-name>
      <param-value>UTF-8param-value>
    init-param>
    <init-param>
      <param-name>forceEncodingparam-name>
      <param-value>trueparam-value>
    init-param>
  filter>
  <filter-mapping>
    <filter-name>encodingFilterfilter-name>
    <url-pattern>/*url-pattern>
  filter-mapping>


  
  <servlet>
    <servlet-name>springServletservlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
    
    <init-param>
      <param-name>contextConfigLocationparam-name>
      <param-value> classpath:spring/applicationContext.xmlparam-value>
    init-param>
    <load-on-startup>1load-on-startup>
  servlet>
  
  <servlet-mapping>
    <servlet-name>springServletservlet-name>
    <url-pattern>/url-pattern>
  servlet-mapping>

  
  <listener>
    <listener-class>
      org.springframework.web.context.ContextLoaderListener
    listener-class>
  listener>
  
  <servlet-mapping>
    <servlet-name>defaultservlet-name>
    <url-pattern>*.mdurl-pattern>
  servlet-mapping>

  <context-param>
    <param-name>contextConfigLocationparam-name>
    <param-value> classpath:spring/applicationContext.xmlparam-value>
  context-param>
  
  <welcome-file-list>
  <welcome-file>/WEB-INF/views/index.jspwelcome-file>
  welcome-file-list>
  
  
  
  
  
  
  <session-config>
    <session-timeout>600session-timeout>
  session-config>
web-app>

这个时候基本的项目配置已经完成了,我们可以先试着启动它看看,等会再配置mybatis。

6. tomcat配置

后台学习一---spring+maven+mybatis+mysql+junit整合_第13张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第14张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第15张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第16张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第17张图片
这里我们选择war exploded模式,网上关于这两个模式的解释是
war模式—-将WEB工程以包的形式上传到服务器
war exploded模式—-将WEB工程以当前文件夹的位置关系上传到服务器
虽然我不是很懂,但做项目习惯用exploded= =
后台学习一---spring+maven+mybatis+mysql+junit整合_第18张图片
这里要注意的是,on frame换成update classes and resources,这样修改了jsp页面不用重启服务器,实现热部署,然后上面的tomcat我们要注意是自己本地的tomcat位置,没有的自己去下一个,接下来启动,看看行不行
后台学习一---spring+maven+mybatis+mysql+junit整合_第19张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第20张图片
ok,正常启动,这个时候springmvc已经完全配置好了,但是ssm框架,还有个mybatis,接下来我们来配置mybatis generator,可以自动帮我们联系数据库生成实体类及映射。

7. mybatis generator配置

先在spring文件里面增加sqlsession配置,将下面这段代码写在applicationContext.xml文件里面



    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        
        <property name="dataSource" ref="dataSource"/>
         <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/>
        <property name="typeAliasesPackage" value="com.springmvc.entity" />

    bean>

    
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        
        <property name="basePackage" value="com.springmvc.dao"/>
        
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
    bean>

然后配置generatorConfig.xml 文件,这是mybatis-generator的配置文件



<generatorConfiguration>
    
    <properties resource="generator.properties"/>

    <classPathEntry  location="C:\Program Files\Java\apache-maven-3.3.3\repo\mysql\mysql-connector-java\5.1.29\mysql-connector-java-5.1.29.jar" />
    <context id="context1">
        
        <commentGenerator>
            <property name="suppressAllComments" value="true" />
            <property name="suppressDate" value="true" /> 
        commentGenerator>

        <jdbcConnection driverClass="${driver}" connectionURL="${url}" userId="${username}" password="${password}" />

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

        <javaModelGenerator targetPackage="${modelPackage}" targetProject="${modelProject}" />
        <sqlMapGenerator targetPackage="${sqlPackage}" targetProject="${sqlProject}" />
        <javaClientGenerator targetPackage="${mapperPackage}" targetProject="${mapperProject}" type="XMLMAPPER" />

        
        <table schema="" tableName="${table}" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"/>

    context>
generatorConfiguration>

值得注意的是上面的classPathEntry location是本地的mysql-connector-java.jar的位置,因为连接数据库是需要驱动的,我们用maven已经自动帮我们下好了jar包,在左边的external libraries里面寻找
后台学习一---spring+maven+mybatis+mysql+junit整合_第21张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第22张图片

然后配置generator.properties文件,这里面保存的是连接数据库的相关信息,是在使用mybatis-generator这个功能的时候用到的;之前的jdbc.properties是系统运行时用到的。二者信息差不多,图方便的话,也可以将两个合并成一个文件,分开写的话,好实现可插拔。

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/example?useUnicode=true&characterEncoding=utf-8
username=root
password=*************

#entity 包名和 java目录
modelPackage=com.springmvc.entity
modelProject=src/main/java
#sqlmap包名 和resources目录
sqlPackage=sqlmap
sqlProject=src/main/resources
#mapper包名和 java目录
mapperPackage=com.springmvc.dao
mapperProject=src/main/java

table=user

这里解释下我已经在本地mysql数据库新建了一个example数据库,里面有一张user表,如果有不太清楚的,可以参考我这篇博客,Mysql5.0+Navicat for MySQL安装,modelPackage是等会连接数据库自动生成的实体类保存的位置,sqlPackage是生成xml映射文件保存的位置,mapperPackage是生成数据库接口保存的位置,table是数据库里面的表的名字
好了,现在都配置好了,让我们来看看这玩意管不管用,我们来执行maven的mybatis-generator操作,双击它
后台学习一---spring+maven+mybatis+mysql+junit整合_第23张图片
然后他就自动生成了关联文件
后台学习一---spring+maven+mybatis+mysql+junit整合_第24张图片
(Tips:如果右侧没有这些功能栏,可以通过view->tool buttons打开后台学习一---spring+maven+mybatis+mysql+junit整合_第25张图片

8. junit测试配置

很多时候我们写完一段代码,想去验证他的正确性,并不一定需要去启动tomcat跑跑看或者debug,我们可以使用测试工具来验证,这儿配置junit测试。
我们来测试一下刚生成的user接口有没有用,因为spring的标签,我们先去usermapper文件加一个@Repository标签,表明它是数据访问组件,即DAO组件
后台学习一---spring+maven+mybatis+mysql+junit整合_第26张图片
然后可以新建测试文件开始测试,将光标移到public interface UserMapper后面,然后键盘上按下alt+enter键,接着create test
后台学习一---spring+maven+mybatis+mysql+junit整合_第27张图片
勾选你要进行测试的函数,点击ok,生成测试文件
后台学习一---spring+maven+mybatis+mysql+junit整合_第28张图片
测试文件里进行测试,我讲我写好的代码贴上来

package com.springmvc.dao;

import com.springmvc.entity.User;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import static org.junit.Assert.*;

/** * Created by 11655 on 2017/3/11. */
public class UserMapperTest {

    private ApplicationContext applicationContext;
    @Autowired
    private UserMapper userMapper;

    @Before
    public void setUp() throws Exception {
        applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");//加载spring配置文件
        userMapper = applicationContext.getBean(UserMapper.class);//在这里导入要测试的
    }

    @After
    public void tearDown() throws Exception {

    }

    @Test
    public void insert() throws Exception {
        User user = new User();
        user.setId(12);
        int result = userMapper.insertSelective(user);
        System.out.println(result);
        assert (result == 1);

    }

}

然后运行test
后台学习一---spring+maven+mybatis+mysql+junit整合_第29张图片
后台学习一---spring+maven+mybatis+mysql+junit整合_第30张图片
成功,我们也可以去数据库看看有没有插入
后台学习一---spring+maven+mybatis+mysql+junit整合_第31张图片

至此,springmvc整合已经完成,我会将这个源码附在下面,大家有什么问题的可以参考一下,如果我有什么讲的不对的地方,也欢迎大家指出

http://download.csdn.net/detail/lxfhahaha/9777662

欢迎加入–qq群–JAVA后台学习交流群:486055993

你可能感兴趣的:(mysql,idea,springmvc,mybatis,maven,SSM框架)