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


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

    1、基本概念


    1.1、Spring


     

            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

     

         

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


    1.3、MyBatis

     


           MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis MyBatis是一个基于Java持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO)MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain 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整合

     

          

            下面主要介绍三大框架的整合,至于环境的搭建以及项目的创建,参看上面的博文。这次整合我分了

     

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

           Spring 4.0.2 RELEASE

           Spring MVC 4.0.2 RELEASE

           MyBatis 3.2.6

    4.1、Maven引入需要的JAR包

             为了方便后面说的时候不需要引入JAR包,我这里 pom.xml

     

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <properties>   
    2. <spring.version></spring.version>   
    3. <mybatis.version></mybatis.version>   
    4. <slf4j.version></slf4j.version> <log4j.version></log4j.version> </properties> <dependencies> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version>   
    5. <scope></scope> </dependency>   
    6. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    7. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    8. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    9. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    10. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    11. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    12. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    13.   
    14. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    15. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    16.   
    17. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency>   
    18. <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> </dependency> </dependencies>  

     

    4.2、Spring与MyBatis的整合

     

     

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


    4.2.1、建立JDBC属性文件

     

     

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. drivercom urljdbc usernamedemao passworddemao initialSize0 maxActive20 maxIdle20 minIdle1 maxWait60000  

    4.2.2、建立spring-mybatis.xml配置文件

            这个文件就是用来完成spring和mybatis的整合的。这里面也没多少行配置,主要的就是

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <?xml= =?> <beans=  
    2. = =  
    3. =  
    4. =  
    5. ="http://www.springframework.org/schema/beans    
    6. >   
    7. <context:component-scan= />   
    8. <bean=  
    9. => <property= = /> </bean> <bean= =  
    10. => <property= = /> <property= = /> <property= = /> <property= = />   
    11. <property= =></property>   
    12. <property= =></property>   
    13. <property= =></property>   
    14. <property= =></property>   
    15. <property= =></property> </bean>   
    16. <bean= => <property= = />   
    17. <property= =></property> </bean>   
    18. <bean=> <property= = /> <property= =></property> </bean>   
    19. <bean=  
    20. => <property= = /> </bean> </beans>  

     


    4.2.3、Log4j的配置

     


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

     

          Log4j的配置很简单,而且也是 http://blog.csdn.net/zhshulin/article/details/37937365

    下面给出配置文件目录:


     

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. log4j.rootLoggerINFO log4j.appender.Consoleorg log4j.appender.Console.TargetSystem log4j.appender.Console.layout.apache.log4j.PatternLayout  
    2. log4j.appender.Console.layout.ConversionPattern log4j.appender.File.apache.log4j.RollingFileAppender  
    3. log4j.appender.File.File/ssm.log  
    4. log4j.appender.File.MaxFileSize  
    5. log4j.appender.File.Threshold  
    6. log4j.appender.File.layout.apache.log4j.PatternLayout  
    7. log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH:mm:ss}][%c]%m%n  

     

    4.2.4、JUnit测试

     


          经过以上步骤(到4.2.2,log4j不配也没影响),我们


    4.2.4.1、创建测试用表

     

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

    [sql] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. DROPTABLE CREATETABLE int  AUTO_INCREMENT,  
    2. varchar ,  
    3. passwordvarchar ,  
    4. int ,  
    5. PRIMARYKEY DEFAULT fortable insertintopasswordvalues,,24);  

    4.2.4.2、利用MyBatis Generator自动创建代码

     

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


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

    4.2.4.3、建立Service接口和实现类

    目录结构:


    下面给出具体的内容:

     

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. package import publicinterface publicint }  

     

     

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. package import import import import import @Service"userService" publicclassimplements   
    2. private   
    3. publicint   
    4. returnthis }  


     

    4.2.4.4、建立测试类

     

     

           测试类        如果测试成功,表示SpringMybatis已经整合成功了。输出信息使用的是Log4j打印到控制台。


    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. package import import import import import import import import import import import import @RunWithclass  
    2. @ContextConfiguration})  
    3. publicclass privatestaticclass //  private ApplicationContext ac = null;   
    4. privatenull //  @Before //  public void before() { //      ac = new ClassPathXmlApplicationContext("applicationContext.xml"); //      userService = (IUserService) ac.getBean("userService"); //  }   
    5. publicvoid );  
    6.   
    7. }  




    至此,

    4.3、整合SpringMVC

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

    4.3.1、配置spring-mvc.xml

    配置里面的注释也很详细,在此就不说了,主要是

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <?xml= =?> <beans=  
    2. = =  
    3. =  
    4. =  
    5. ="http://www.springframework.org/schema/beans    
    6. >   
    7. <context:component-scan= />   
    8. <bean=  
    9. => <property=> <list> <value>=-8</value> </list> </property> </bean>   
    10. <bean => <property=> <list> <ref= />  
    11. </list> </property> </bean>   
    12. <bean=>   
    13. <property= = /> <property= = /> </bean>   
    14. <bean=    
    15. =>   
    16. <property= = />   
    17. <property= = />   
    18. <property= = /> </bean> </beans>  


    4.3.2、配置web.xml文件

     

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


     

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <?xml= =?> <web-app=  
    2. =  
    3. = => <display-name></display-name>   
    4. <context-param> <param-name></param-name> <param-value></param-value> </context-param>   
    5. <filter> <filter-name></filter-name> <filter-class></filter-class> <async-supported></async-supported> <init-param> <param-name></param-name> <param-value></param-value> </init-param> </filter> <filter-mapping> <filter-name></filter-name> <url-pattern></url-pattern> </filter-mapping>   
    6. <listener> <listener-class></listener-class> </listener>   
    7. <listener> <listener-class></listener-class> </listener>   
    8. <servlet> <servlet-name></servlet-name> <servlet-class></servlet-class> <init-param> <param-name></param-name> <param-value></param-value> </init-param> <load-on-startup></load-on-startup> <async-supported></async-supported> </servlet> <servlet-mapping> <servlet-name></servlet-name>   
    9. <url-pattern></url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file></welcome-file> </welcome-file-list> </web-app>  


    4.3.3、测试

     

            至此已经完成了SSM三大框架的整合了,接下来测试一下,如果成功了,那么恭喜你,如果失败了,继续调试吧,

    4.3.3.1、新建jsp页面


    完整的简单流程。

     

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <= = =%> > <html> <head> <title></title> </head> <body> </body> </html>  


     

    4.3.3.2、建立UserController类

     

    UserController.java  控制器

     

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. package import import import import import import import @Controller @RequestMapping"/user" publicclass   
    2. private ()  
    3. public int));  
    4. this , user);  
    5. return;  
    6. }  


     

    4.3.3.3、部署项目

     

     

    输入地址:localhost:8080/项目名称/user/showUser?id=1

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


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


     (转载注明出处:http://blog.csdn.net/zhshulin

  • 相关阅读:
    每日一练4
    每日一练3
    每日一练2 字符串逆序输出
    每日一练1
    python全局变量
    python __file__ 与argv[0]
    python 静态方法和类方法
    常用的python库(不断更新)
    django 自定义用户user模型的三种方法
    实例详解Django的 select_related 和 prefetch_related 函数对 QuerySet 查询的优化(三)
  • 原文地址:https://www.cnblogs.com/jinlinFighting/p/5684660.html
Copyright © 2020-2023  润新知