SpringMVC+MyBatis(最新)

Easter79
• 阅读 522

目前主流的Web MVC框架,除了Struts这个主力 外,还有Spring MVC,主要是由于Spring MVC配置比较简单,使用起来也十分明了,非常灵活,与Spring 集成较好,对RESTful API的支持也比struts要好。
MyBatis是ibatis的升级版,作为hibernate的老对手,它 是一个可以自定义SQL、存储过程和高级映射的持久层框架。
与hibernate的主要区别就是mybatis是半自动化的,而hibernate是全自动的,所以当应用需求越来越复杂的时候,自动化的sql显得比较笨拙。
由于前段时间接了个项目要用springmvc做,所以我抱着练手的态度,又玩起了整合框架的游戏。经常搭框架的人应该都清楚,框架搭建的核心就是配置文件。所以我主要贴下几个配置文件的代码。还是那句话,我都是写好配置文件之后,运行报错再加jar。这里列一下我用的jar包(应该是最少的):
SpringMVC+MyBatis(最新)
备注:上图有一些额外的jar,比如我用的数据库连接池是阿里巴巴的druid、日志框架式logback,所以引入了相关jar。关于这两个框架的使用和配置都是非常简单的,所以这里就不细说。
1.整合SpringMVC
springMybatis-servlet.xml:

[html] view plain copy

 print?

  1.     

  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   

  3.        xmlns:context="http://www.springframework.org/schema/context"  

  4.        xmlns:mvc="http://www.springframework.org/schema/mvc"  

  5.        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  

  6.         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd  

  7.         http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">  

  8.           

  9.     mvc:annotation-driven   

  10.       

  11.       

  12.     <context:component-scan base-package="com.alibaba.controller" />  

  13.     <context:component-scan base-package="com.alibaba.service"/>  

  14.         

  15.         

  16.             

  17.             

  18.         

  19.        

  20.     mvc:interceptors    

  21.         mvc:interceptor    

  22.               

  23.             <mvc:mapping path="/" />  

  24.             <mvc:mapping path="/user/**" />  

  25.             <mvc:mapping path="/test/**" />  

  26.                 

  27.           

  28.           

  29.       

     

2.整合Mybatis

spring-dao.xml:

[html] view plain copy

 print?

  1.     

  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   

  3.        xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"  

  4.        xmlns:context="http://www.springframework.org/schema/context"  

  5.        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  

  6.        http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring.xsd  

  7.        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">  

  8.       

  9.     <mybatis:scan base-package="com.alibaba.dao"/>  

  10.       

  11.     <context:property-placeholder location="classpath:configuration.properties"/>  

  12.       

  13.        

  14.           

  15.           

  16.           

  17.           

  18.         1  

  19.         5  

  20.         1  

  21.           

  22.         60000  

  23.           

  24.         stat  

  25.           

  26.         60000  

  27.           

  28.         300000  

  29.         <!--  

  30.         SELECT 'x'  

  31.         true  

  32.         false  

  33.         false  

  34.         true  

  35.         20  

  36.          -->  

  37.       

  38.       

  39.       

  40.           

  41.        

     

3.web.xml整合SpringMVC和Mybatis

[html] view plain copy

 print?

  1.   

  2.   

  3.       

  4.       

  5.       

  6.         default  

  7.         /js/*  

  8.         /css/*  

  9.         /images/*  

  10.         /fonts/*  

  11.       

  12.       

  13.       

  14.         encodingFilter  

  15.         org.springframework.web.filter.CharacterEncodingFilter  

  16.           

  17.             encoding  

  18.             UTF-8  

  19.           

  20.           

  21.             forceEncoding  

  22.             true  

  23.           

  24.       

  25.       

  26.         encodingFilter  

  27.         /*  

  28.       

  29.     <!-- 初始化 DispatcherServlet时,该框架在 web应用程序WEB-INF目录中寻找一个名为[servlet-名称]-servlet.xml的文件,  

  30.             并在那里定义相关的Beans,重写在全局中定义的任何Beans -->  

  31.       

  32.         springMybatis  

  33.         org.springframework.web.servlet.DispatcherServlet  

  34.         1  

  35.       

  36.       

  37.         springMybatis  

  38.           

  39.         /  

  40.       

  41.       

  42.         contextConfigLocation  

  43.         /WEB-INF/config/spring-*.xml  

  44.       

  45.       

  46.         org.springframework.web.context.ContextLoaderListener  

  47.       

  48.       

  49.       

  50.         DruidStatView  

  51.         com.alibaba.druid.support.http.StatViewServlet  

  52.       

  53.       

  54.         DruidStatView  

  55.         /druid/*  

  56.       

  57.       

  58.         404  

  59.         /error/404.jsp  

  60.       

  61.       

  62.         500  

  63.         /error/500.jsp  

  64.       

  

4.logback.xml日志配置

[html] view plain copy

 print?

  1.   

  2.   

  3.     

  4.         

  5.         %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n  

  6.       

  7.     

  8.     

  9.     

  10.     

  11.     

  12.     

  13.       

  14.     

  

5.configuration.properties配置

[html] view plain copy

 print?

  1. jdbc.url=jdbc\:mysql\://localhost\:3306/druid?useUnicode\=true&characterEncoding\=UTF-8&zeroDateTimeBehavior\=convertToNull  
  2. jdbc.username=root  
  3. jdbc.password=123456

  

6.测试搭建是否成功,后台代码

首先是登录,用了加密,可以去掉

[java] view plain copy

 print?

  1. package com.alibaba.controller;  

  2. import javax.annotation.Resource;  

  3. import javax.servlet.http.HttpServletRequest;  

  4. import org.apache.commons.codec.digest.DigestUtils;  

  5. import org.slf4j.Logger;  

  6. import org.slf4j.LoggerFactory;  

  7. import org.springframework.stereotype.Controller;  

  8. import org.springframework.web.bind.annotation.RequestMapping;  

  9. import org.springframework.web.bind.annotation.RequestMethod;  

  10. import org.springframework.web.bind.annotation.RequestParam;  

  11. import com.alibaba.model.User;  

  12. import com.alibaba.service.UserService;  

  13. import com.alibaba.util.RequestUtil;  

  14. /** 

  15.  * @author tfj 

  16.  * 2014-7-26 

  17.  */  

  18. @Controller  

  19. public class SystemController {  

  20.     private final Logger log = LoggerFactory.getLogger(SystemController.class);  

  21.     @Resource  

  22.     private UserService userService;  

  23.     @RequestMapping(value = "/",method = RequestMethod.GET)  

  24.     public String home() {  

  25.         log.info("返回首页!");  

  26.         return "index";  

  27.     }  

  28.     @RequestMapping(value = "/test/hello",method = RequestMethod.GET)  

  29.     public String testHello() {  

  30.         log.info("执行了testHello方法!");  

  31.         return "testHello";  

  32.     }  

  33.     @RequestMapping(value = "/login",method = RequestMethod.POST)  

  34.     public String testLogin(HttpServletRequest request,@RequestParam String username, @RequestParam String password) {  

  35.         log.info("执行了testLogin方法!");  

  36.         User user = userService.findUserByName(username);  

  37.         if(user!=null){  

  38.             if(user.getPassword().equals(DigestUtils.md5Hex(password))){  

  39.                 request.getSession().setAttribute("userId", user.getId());    

  40.                 request.getSession().setAttribute("user", username);    

  41.                 return "redirect:" + RequestUtil.retrieveSavedRequest();//跳转至访问页面  

  42.             }else{  

  43.                 log.info("密码错误");    

  44.                 request.getSession().setAttribute("message", "用户名密码错误,请重新登录");  

  45.                 return "login";   

  46.             }  

  47.         }else{  

  48.             log.info("用户名不存在");    

  49.             request.getSession().setAttribute("message", "用户名不存在,请重新登录");  

  50.             return "login";   

  51.         }  

  52.     }  

  53. }  

  54.       

  55.       

  56.         select id, username , password from sysuser where username = #{username}   

  57.       

  

目前主流的Web MVC框架,除了Struts这个主力 外,还有Spring MVC,主要是由于Spring MVC配置比较简单,使用起来也十分明了,非常灵活,与Spring 集成较好,对RESTful API的支持也比struts要好。
MyBatis是ibatis的升级版,作为hibernate的老对手,它 是一个可以自定义SQL、存储过程和高级映射的持久层框架。
与hibernate的主要区别就是mybatis是半自动化的,而hibernate是全自动的,所以当应用需求越来越复杂的时候,自动化的sql显得比较笨拙。
由于前段时间接了个项目要用springmvc做,所以我抱着练手的态度,又玩起了整合框架的游戏。经常搭框架的人应该都清楚,框架搭建的核心就是配置文件。所以我主要贴下几个配置文件的代码。还是那句话,我都是写好配置文件之后,运行报错再加jar。这里列一下我用的jar包(应该是最少的):
SpringMVC+MyBatis(最新)
备注:上图有一些额外的jar,比如我用的数据库连接池是阿里巴巴的druid、日志框架式logback,所以引入了相关jar。关于这两个框架的使用和配置都是非常简单的,所以这里就不细说。
1.整合SpringMVC
springMybatis-servlet.xml:

 print?

  1.     

  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   

  3.        xmlns:context="http://www.springframework.org/schema/context"  

  4.        xmlns:mvc="http://www.springframework.org/schema/mvc"  

  5.        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  

  6.         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd  

  7.         http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">  

  8.           

  9.     mvc:annotation-driven   

  10.       

  11.       

  12.     <context:component-scan base-package="com.alibaba.controller" />  

  13.     <context:component-scan base-package="com.alibaba.service"/>  

  14.         

  15.         

  16.             

  17.             

  18.         

  19.        

  20.     mvc:interceptors    

  21.         mvc:interceptor    

  22.               

  23.             <mvc:mapping path="/" />  

  24.             <mvc:mapping path="/user/**" />  

  25.             <mvc:mapping path="/test/**" />  

  26.                 

  27.           

  28.           

  29.       

     

2.整合Mybatis

spring-dao.xml:

[html] view plain copy

 print?

  1.     

  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   

  3.        xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"  

  4.        xmlns:context="http://www.springframework.org/schema/context"  

  5.        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  

  6.        http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring.xsd  

  7.        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">  

  8.       

  9.     <mybatis:scan base-package="com.alibaba.dao"/>  

  10.       

  11.     <context:property-placeholder location="classpath:configuration.properties"/>  

  12.       

  13.        

  14.           

  15.           

  16.           

  17.           

  18.         1  

  19.         5  

  20.         1  

  21.           

  22.         60000  

  23.           

  24.         stat  

  25.           

  26.         60000  

  27.           

  28.         300000  

  29.         <!--  

  30.         SELECT 'x'  

  31.         true  

  32.         false  

  33.         false  

  34.         true  

  35.         20  

  36.          -->  

  37.       

  38.       

  39.       

  40.           

  41.        

     

3.web.xml整合SpringMVC和Mybatis

[html] view plain copy

 print?

  1.   

  2.   

  3.       

  4.       

  5.       

  6.         default  

  7.         /js/*  

  8.         /css/*  

  9.         /images/*  

  10.         /fonts/*  

  11.       

  12.       

  13.       

  14.         encodingFilter  

  15.         org.springframework.web.filter.CharacterEncodingFilter  

  16.           

  17.             encoding  

  18.             UTF-8  

  19.           

  20.           

  21.             forceEncoding  

  22.             true  

  23.           

  24.       

  25.       

  26.         encodingFilter  

  27.         /*  

  28.       

  29.     <!-- 初始化 DispatcherServlet时,该框架在 web应用程序WEB-INF目录中寻找一个名为[servlet-名称]-servlet.xml的文件,  

  30.             并在那里定义相关的Beans,重写在全局中定义的任何Beans -->  

  31.       

  32.         springMybatis  

  33.         org.springframework.web.servlet.DispatcherServlet  

  34.         1  

  35.       

  36.       

  37.         springMybatis  

  38.           

  39.         /  

  40.       

  41.       

  42.         contextConfigLocation  

  43.         /WEB-INF/config/spring-*.xml  

  44.       

  45.       

  46.         org.springframework.web.context.ContextLoaderListener  

  47.       

  48.       

  49.       

  50.         DruidStatView  

  51.         com.alibaba.druid.support.http.StatViewServlet  

  52.       

  53.       

  54.         DruidStatView  

  55.         /druid/*  

  56.       

  57.       

  58.         404  

  59.         /error/404.jsp  

  60.       

  61.       

  62.         500  

  63.         /error/500.jsp  

  64.       

  

4.logback.xml日志配置

[html] view plain copy

 print?

  1.   

  2.   

  3.     

  4.         

  5.         %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n  

  6.       

  7.     

  8.     

  9.     

  10.     

  11.     

  12.     

  13.       

  14.     

  

5.configuration.properties配置

[html] view plain copy

 print?

  1. jdbc.url=jdbc\:mysql\://localhost\:3306/druid?useUnicode\=true&characterEncoding\=UTF-8&zeroDateTimeBehavior\=convertToNull  
  2. jdbc.username=root  
  3. jdbc.password=123456

  

6.测试搭建是否成功,后台代码

首先是登录,用了加密,可以去掉

[java] view plain copy

 print?

  1. package com.alibaba.controller;  

  2. import javax.annotation.Resource;  

  3. import javax.servlet.http.HttpServletRequest;  

  4. import org.apache.commons.codec.digest.DigestUtils;  

  5. import org.slf4j.Logger;  

  6. import org.slf4j.LoggerFactory;  

  7. import org.springframework.stereotype.Controller;  

  8. import org.springframework.web.bind.annotation.RequestMapping;  

  9. import org.springframework.web.bind.annotation.RequestMethod;  

  10. import org.springframework.web.bind.annotation.RequestParam;  

  11. import com.alibaba.model.User;  

  12. import com.alibaba.service.UserService;  

  13. import com.alibaba.util.RequestUtil;  

  14. /** 

  15.  * @author tfj 

  16.  * 2014-7-26 

  17.  */  

  18. @Controller  

  19. public class SystemController {  

  20.     private final Logger log = LoggerFactory.getLogger(SystemController.class);  

  21.     @Resource  

  22.     private UserService userService;  

  23.     @RequestMapping(value = "/",method = RequestMethod.GET)  

  24.     public String home() {  

  25.         log.info("返回首页!");  

  26.         return "index";  

  27.     }  

  28.     @RequestMapping(value = "/test/hello",method = RequestMethod.GET)  

  29.     public String testHello() {  

  30.         log.info("执行了testHello方法!");  

  31.         return "testHello";  

  32.     }  

  33.     @RequestMapping(value = "/login",method = RequestMethod.POST)  

  34.     public String testLogin(HttpServletRequest request,@RequestParam String username, @RequestParam String password) {  

  35.         log.info("执行了testLogin方法!");  

  36.         User user = userService.findUserByName(username);  

  37.         if(user!=null){  

  38.             if(user.getPassword().equals(DigestUtils.md5Hex(password))){  

  39.                 request.getSession().setAttribute("userId", user.getId());    

  40.                 request.getSession().setAttribute("user", username);    

  41.                 return "redirect:" + RequestUtil.retrieveSavedRequest();//跳转至访问页面  

  42.             }else{  

  43.                 log.info("密码错误");    

  44.                 request.getSession().setAttribute("message", "用户名密码错误,请重新登录");  

  45.                 return "login";   

  46.             }  

  47.         }else{  

  48.             log.info("用户名不存在");    

  49.             request.getSession().setAttribute("message", "用户名不存在,请重新登录");  

  50.             return "login";   

  51.         }  

  52.     }  

  53. }

  

源码来源: minglisoft.cn/technology

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
Java获得今日零时零分零秒的时间(Date型)
publicDatezeroTime()throwsParseException{    DatetimenewDate();    SimpleDateFormatsimpnewSimpleDateFormat("yyyyMMdd00:00:00");    SimpleDateFormatsimp2newS
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
4个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
Easter79
Easter79
Lv1
今生可爱与温柔,每一样都不能少。
文章
2.8k
粉丝
5
获赞
1.2k