分享

spring4.3

 昵称27831725 2017-11-21
写在前面的话:

现在是北京时间2016年11月2日凌晨1点10分18秒,我在这里写下这篇博客,希望能帮到有需要的朋友,由于个人水平有限,有不正确的地方还请各位多多指教,不甚感激!


前期工作准备

1、软件准备

JDK:1.7

IDE:Eclipse mars

Spring:4.3.0

Spring Mvc:4.3.0

MyBatis:3.4.0

数据库:mysql-5.6.24

2、硬件准备:

本尊(全球限量一个,产地:贵州凯里,当前版本:23.0,型号:男),华硕笔记本一台,好视力台灯一台,椅子一张。


正式开始配置

本来想一边讲解配置过程,一边创建目录,但是这样感觉不是很清晰,所以我干脆先把工程结构贴出来,方便大家对整个项目的结构有个大概了解,小小的运用了先全局后部分的哲学思想,哈哈。看,这就是我们要完成的工程图

看着好复杂的样子,不过不要害怕,作为一名合格的程序员就应该有跟bug革命到底的精神,下面我们来开始配置项目。


1.配置数据库

右键项目新建一个config源文件夹,用来存放我们的各种配置文件。然后在config下新建文件jdbc.properties,这个文件用来配置数据库信息,内容如下:

  1. #MySql 数据库驱动  
  2. jdbc.driver=com.mysql.jdbc.Driver  
  3. #jdbc:mysql://连接地址:端口号(默认3306)/数据库名  
  4. jdbc.url=jdbc:mysql://127.0.0.1:3306/spring  
  5. #用户名  
  6. jdbc.username=root  
  7. #密码  
  8. jdbc.password=123456  
  9. #连接池初始化连接  
  10. jdbc.initialSize=0  
  11. #连接池最大连接数  
  12. jdbc.maxActive=20  
  13. #连接池最大空闲连接  
  14. jdbc.maxIdle=20  
  15. #连接池最小空闲连接  
  16. jdbc.minIdle=1  
  17. #等待超时  
  18. jdbc.maxWait=60000</span>  

代码都有注释,不再累述。

2.配置日志log4j

在项目下新建文件夹logs,日志文件将往这里面写;同样在config下新建文件log4j.properties,里面是关于日志的一些配置,内容如下:

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

3.spring与mybatis的结合(主角登场,鼓掌)

在config目录下新建一个xml文件,命名为spring-mybatis.xml,内容如下

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www./schema/beans" xmlns:context="http://www./schema/context" xmlns:xsi="http://www./2001/XMLSchema-instance" xmlns:aop="http://www./schema/aop"    
  3.     xmlns:tx="http://www./schema/tx" xmlns:p="http://www./schema/p" xmlns:util="http://www./schema/util" xmlns:jdbc="http://www./schema/jdbc"    
  4.     xmlns:cache="http://www./schema/cache"    
  5.     xsi:schemaLocation="    
  6.     http://www./schema/context    
  7.     http://www./schema/context/spring-context.xsd    
  8.     http://www./schema/beans    
  9.     http://www./schema/beans/spring-beans.xsd    
  10.     http://www./schema/tx    
  11.     http://www./schema/tx/spring-tx.xsd    
  12.     http://www./schema/jdbc    
  13.     http://www./schema/jdbc/spring-jdbc-3.1.xsd    
  14.     http://www./schema/aop    
  15.     http://www./schema/aop/spring-aop.xsd  
  16.     http://www./schema/mvc    
  17.     http://www./schema/mvc/spring-mvc-4.0.xsd">   
  18.       
  19.     <!-- 自动扫描 -->  
  20.     <context:component-scan base-package="com.pyx" />  
  21.     <!-- 引入配置文件 -->  
  22.     <bean id="propertyConfigurer"  
  23.         class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
  24.         <property name="location" value="classpath:jdbc.properties" />  
  25.     </bean>  
  26.   
  27.     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"  
  28.         destroy-method="close">  
  29.         <property name="driverClassName" value="${jdbc.driver}" />  
  30.         <property name="url" value="${jdbc.url}" />  
  31.         <property name="username" value="${jdbc.username}" />  
  32.         <property name="password" value="${jdbc.password}" />  
  33.         <!-- 初始化连接大小 -->  
  34.         <property name="initialSize" value="${jdbc.initialSize}"></property>  
  35.         <!-- 连接池最大数量 -->  
  36.         <property name="maxActive" value="${jdbc.maxActive}"></property>  
  37.         <!-- 连接池最大空闲 -->  
  38.         <property name="maxIdle" value="${jdbc.maxIdle}"></property>  
  39.         <!-- 连接池最小空闲 -->  
  40.         <property name="minIdle" value="${jdbc.minIdle}"></property>  
  41.         <!-- 获取连接最大等待时间 -->  
  42.         <property name="maxWait" value="${jdbc.maxWait}"></property>  
  43.     </bean>  
  44.   
  45.     <!-- 配置spring与mybatis结合 -->  
  46.     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  47.         <property name="dataSource" ref="dataSource" />  
  48.         <!-- 自动扫描mapping.xml文件 -->  
  49.         <property name="mapperLocations" value="classpath:com/pyx/mapper/*.xml"></property>  
  50.     </bean>  
  51.   
  52.     <!-- DAO接口所在包名,Spring会自动查找其下的类 -->  
  53.     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
  54.         <property name="basePackage" value="com.pyx.dao" />  
  55.         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>  
  56.     </bean>  
  57.   
  58.     <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->  
  59.     <bean id="transactionManager"  
  60.         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
  61.         <property name="dataSource" ref="dataSource" />  
  62.     </bean>  
  63.     <!-- 这个必须配置,否则事物不起作用 -->  
  64.     <tx:annotation-driven transaction-manager="transactionManager"/>  
  65. </beans>  

为了测试,只配置了最基本的功能,你可以根据自己的项目需求进行配置。

4.测试spring与mybatis的整合

在src源文件夹下新建以下包


看文件名应该能猜出个大概,这些包类有哪些功能,你应该明白,如果不明白,建议你还是再学学框架吧。

在数据库新建一张user表用于测试,我的表结构如下:

表建好后根据你的表字段就可以编写dao,mapper和Pojo了,这里介绍一个自动生成mybatis mapper的jar,参考下面的博文:

SSM框架——使用MyBatis Generator自动创建代码

新手不建议使用,还是自己手写比较好,把生成的文件复制到项目中,然后开始编写测试代码。新建test源文件夹,编写一个测试类。


  1. package com.pyx.test;  
  2.   
  3. import javax.annotation.Resource;  
  4.   
  5. import org.junit.Test;  
  6. import org.junit.runner.RunWith;  
  7. import org.springframework.test.context.ContextConfiguration;  
  8. import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;  
  9.   
  10. import com.pyx.pojo.User;  
  11. import com.pyx.service.UserService;  
  12.   
  13. @RunWith(SpringJUnit4ClassRunner.class)       
  14. @ContextConfiguration(locations = {"classpath:spring-mybatis.xml"})  
  15.   
  16. public class TestMyBatis {  
  17.   
  18.     @Resource  
  19.     private UserService userService = null;  
  20.   
  21.   
  22.     @Test  
  23.     public void mytest() {  
  24.         User user = userService.getUserById(1);  
  25.          System.out.println("查询结果:"+user.getUsername());  
  26.     }  
  27. }  

这里有几点要注意:

1,因为用了JUnit4插件测试,所以务必确认你的项目中已经加入JUnit4类库,否则会报找不到mytest方法的错误。

2,    <!-- spring和MyBatis的整合配置 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <!-- 自动扫描mapping.xml文件 -->
        <property name="mapperLocations" value="classpath:com/pyx/mapper/*.xml"></property>
    </bean>

这里的mapperLocations一定要写对,我就是因为mapper后面少了一个“/”,所以一直在报找补到mapper方法的错误,还有如果你是用自动生成工具生成的代码,那请你一定要留意mapper文件中的包名是否正确,其他两个pojo和dao如果包名不对会立即显示错误的,但是mapper就不会,所以如果tomcat启动异常,一定要查看这个文件。

接下来开始测试,选择mytest方法右键调试方式->JUnit4测试,如果控制台输出如下结果,表示spring与mybatis已经整合成功,如果报错,根据bug信息慢慢调试吧。

5.整合spring mvc

config下新建spring-mvc.xml文件,内容如下

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www./schema/beans"  
  3.     xmlns:xsi="http://www./2001/XMLSchema-instance" xmlns:p="http://www./schema/p"  
  4.     xmlns:context="http://www./schema/context"  
  5.     xmlns:mvc="http://www./schema/mvc"  
  6.     xsi:schemaLocation="http://www./schema/beans    
  7.     http://www./schema/beans/spring-beans-3.1.xsd    
  8.     http://www./schema/context    
  9.     http://www./schema/context/spring-context-3.1.xsd    
  10.     http://www./schema/mvc    
  11.     http://www./schema/mvc/spring-mvc-4.0.xsd">  
  12.     <!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 -->  
  13.     <context:component-scan base-package="com.pyx.controller" />  
  14.     <!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 -->  
  15.     <bean  
  16.         class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">  
  17.     </bean>  
  18.     <!-- 定义跳转的文件的前后缀 ,视图模式配置-->  
  19.     <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
  20.         <property name="prefix" value="/WEB-INF/jsp/" />  
  21.         <property name="suffix" value=".jsp" />  
  22.     </bean>  
  23.       
  24.     <!-- 配置返回Json数据 -->  
  25.     <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">  
  26.         <property name="messageConverters">  
  27.             <list>  
  28.                 <ref bean="mappingJacksonHttpMessageConverter"/>  
  29.             </list>  
  30.         </property>  
  31.     </bean>  
  32.     <bean id="mappingJacksonHttpMessageConverter"  
  33.         class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">  
  34.         <property name="supportedMediaTypes">  
  35.             <list>  
  36.                 <value>text/html;charset=UTF-8</value>  
  37.             </list>  
  38.         </property>  
  39.     </bean>  
  40.     <!-- 特别重要,不配置该项,使用ajax请求时会报406错误 -->  
  41.     <mvc:annotation-driven></mvc:annotation-driven>  
  42.       
  43.       
  44. </beans>  

配置web.xml
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app xmlns:xsi="http://www./2001/XMLSchema-instance"  
  3.     xmlns="http://java./xml/ns/javaee"  
  4.     xsi:schemaLocation="http://java./xml/ns/javaee http://java./xml/ns/javaee/web-app_3_0.xsd"  
  5.     version="3.0">  
  6.     <display-name>Spring Mybatis</display-name>  
  7.     <!-- 加载Spring和mybatis的配置文件 -->  
  8.     <context-param>  
  9.         <param-name>contextConfigLocation</param-name>  
  10.         <param-value>classpath:spring-mybatis.xml</param-value>  
  11.     </context-param>  
  12.     <!-- 编码过滤器 -->  
  13.     <filter>  
  14.         <filter-name>encodingFilter</filter-name>  
  15.         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
  16.         <async-supported>true</async-supported>  
  17.         <init-param>  
  18.             <param-name>encoding</param-name>  
  19.             <param-value>UTF-8</param-value>  
  20.         </init-param>  
  21.     </filter>  
  22.     <filter-mapping>  
  23.         <filter-name>encodingFilter</filter-name>  
  24.         <url-pattern>/*</url-pattern>  
  25.     </filter-mapping>  
  26.     <!-- Spring监听器 -->  
  27.     <listener>  
  28.         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
  29.     </listener>  
  30.   
  31.     <!-- Spring MVC servlet -->  
  32.     <servlet>  
  33.         <servlet-name>SpringMVC</servlet-name>  
  34.         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
  35.         <init-param>  
  36.             <param-name>contextConfigLocation</param-name>  
  37.             <param-value>classpath:spring-mvc.xml</param-value>  
  38.         </init-param>  
  39.         <load-on-startup>1</load-on-startup>  
  40.         <async-supported>true</async-supported>  
  41.     </servlet>  
  42.     <servlet-mapping>  
  43.         <servlet-name>SpringMVC</servlet-name>  
  44.         <url-pattern>/</url-pattern>  
  45.     </servlet-mapping>  
  46.       
  47.     <!-- 配置过滤静态文件,如js,css,image等,方法不止这一种,自己百度有很多其他更好的方法 -->  
  48.     <servlet-mapping>  
  49.         <servlet-name>default</servlet-name>  
  50.         <url-pattern>/static/*</url-pattern>  
  51.     </servlet-mapping>  
  52.       
  53.     <welcome-file-list>  
  54.         <welcome-file>/index.jsp</welcome-file>  
  55.     </welcome-file-list>  
  56.       
  57. </web-app>  

在controller包下建一个控制器,就叫UserController吧,内容如下
  1. package com.pyx.controller;  
  2.   
  3. import java.util.Date;  
  4.   
  5. import javax.annotation.Resource;  
  6. import javax.servlet.http.HttpServletRequest;  
  7.   
  8. import org.springframework.stereotype.Controller;  
  9. import org.springframework.ui.Model;  
  10. import org.springframework.web.bind.annotation.RequestMapping;  
  11. import org.springframework.web.bind.annotation.RequestMethod;  
  12. import org.springframework.web.bind.annotation.ResponseBody;  
  13.   
  14. import com.pyx.pojo.User;  
  15. import com.pyx.service.UserService;  
  16.   
  17. @Controller  
  18. @RequestMapping("/user")  
  19. public class UserController {  
  20.   
  21.     @Resource  
  22.     private UserService userService;  
  23.       
  24.       
  25.     //查询用户  
  26.     @RequestMapping("/list")  
  27.     public String list(HttpServletRequest request,Model model){  
  28.         int userId = Integer.parseInt(request.getParameter("id"));  
  29.         User user = this.userService.getUserById(userId);  
  30.         model.addAttribute("user", user);  
  31.         return "user";  
  32.     }  
  33.       
  34.     //更新用户  
  35.     @RequestMapping("/update")  
  36.     public String update(HttpServletRequest request,Model model){  
  37.         int userId = Integer.parseInt(request.getParameter("id"));  
  38.         User user = new User();  
  39.         user.setSid(userId);  
  40.         user.setUsername("隔壁老王");  
  41.         user.setPassword("258258");  
  42.         int status = this.userService.updateUserById(user);  
  43.         model.addAttribute("msg", status);  
  44.         return "ok";  
  45.     }  
  46.       
  47.     //添加用户  
  48.     @RequestMapping("/add")  
  49.     public String addUser(HttpServletRequest request,Model model) {  
  50.         User user = new User();  
  51.         //SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yy-mm-dd");  
  52.         Date birth=null;  
  53.         user.setUsername("panyx");  
  54.         user.setPassword("258258");  
  55.         user.setBirth(birth);  
  56.         user.setEmail("ape010@163.com");  
  57.         user.setSex("女");  
  58.         int status = this.userService.insertUser(user);  
  59.         model.addAttribute("msg", status);  
  60.         return "add-ok";  
  61.           
  62.     }  
  63.       
  64.     //ajax测试页面  
  65.     @RequestMapping("/test")  
  66.     public String mytest(Model model){  
  67.         return "test";  
  68.     }  
  69.       
  70.     //测试ajax请求,返回json数据  
  71.     @RequestMapping(value="jsontest", method=RequestMethod.POST)  
  72.     @ResponseBody  
  73.     public User jsonTest(Model model){  
  74.         User user = this.userService.getUserById(1);  
  75.         return user;  
  76.     }  
  77. }  
/WEB-INF/jsp,新建一个user.jsp测试页面
  1. <%@ page language="java" contentType="text/html; charset=utf-8"  
  2.     pageEncoding="utf-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www./TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  7. <title>测试</title>  
  8. </head>  
  9. <body>  
  10.     ${user.username}  
  11. </body>  
  12. </html>  


6.测试spring mvc

启动tomcat,浏览器输入http://localhost:8080/你的项目名/user/list?id=1

如果能出现上图的效果就说明我们的框架整合完美结束了,但在实际开发中,肯定会用到ajax,那我们就再配置一下ajax吧,其实在spring-mvc.xml中我们已经做了返回json数据的配置,只要把jackson.jar包引进去就可以了。我们再写一个测试页面,用来测试ajax,test.jsp

  1. <%@ page language="java" contentType="text/html; charset=utf-8"  
  2.     pageEncoding="utf-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www./TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  7. <title>ajax测试</title>  
  8. <script src="${pageContext.request.contextPath}/static/js/jquery.min.js"></script>  
  9. </head>  
  10. <body>  
  11.      <p>  
  12.     <button id="testbtn" class="" >找老王</button>  
  13.  </p>  
  14.  <script>  
  15.     $(function(){  
  16.         $("#testbtn").bind("click",function(){  
  17.             $.ajax({  
  18.                 url:"http://localhost:8080/myspring/user/jsontest",  
  19.                 type:"post",  
  20.                 async:true,  
  21.                 data:{},  
  22.                 dataType:"json",  
  23.                 success:function(data){  
  24.                     console.log(data);  
  25.                 }  
  26.                   
  27.             })  
  28.         });  
  29.     })  
  30.  </script>  
  31. </body>  
  32. </html>  

方法在UserController中都已经写好了,在浏览器中输入:http://localhost:8080/myspring/user/test,



到此,spring,spring-mvc,mybatis完美的融合在了一起!



特别感谢:

参考了博主shu_lin的文章,SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

SSM框架——使用MyBatis Generator自动创建代码


工程所需jar包下载:spring-4.3.0和mybatis-3.4整合所需jar包

提取码:vsk7


    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约