spring+springMVC+Mybatis整合
2016-02-15 15:26
936 查看
首先准备整合需要的jar包,我都是去官网下载的最新jar文件具体需要的jar文件如图:
创建的项目结构如图:
首先数据库配置文件jdbc.properties内容如下:
IUserService.java内容:
userlist.jsp内容如下:
运行地址:http://localhost:8080/SSM/user/showUser.do?id=1
运行地址:http://localhost:8080/SSM/user/userList.do
整合完毕。
源码下载地址:http://download.csdn.net/detail/gaoxuaiguoyi/9431979
创建的项目结构如图:
首先数据库配置文件jdbc.properties内容如下:
driver=com.mysql.jdbc.Driver url=jdbc:mysql://127.0.0.1:3306/ssm username=root password=root initialSize=0 maxIdle=20 minIdle=1log4j.properties内容如下:
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 # 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志 log4j.appender.File.Threshold = ALL log4j.appender.File.layout = org.apache.log4j.PatternLayout log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%nspring-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-4.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd"> <!-- 自动扫描 --> <context:component-scan base-package="com.project.ssm" /> <!-- 引入配置文件 --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location" value="classpath:jdbc.properties" /> </bean> <bean id="dataSource" class="org.apache.commons.dbcp2.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="maxIdle" value="${maxIdle}"></property> <!-- 连接池最小空闲 --> <property name="minIdle" value="${minIdle}"></property> </bean> <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <!-- 自动扫描mapping.xml文件 --> <property name="mapperLocations" value="classpath:com/project/ssm/mapping/*.xml"></property> </bean> <!-- DAO接口所在包名,Spring会自动查找其下的类 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.project.ssm.dao" /> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property> </bean> <!-- (事务管理) --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> </beans>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-4.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd"> <!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 --> <context:component-scan base-package="com.project.ssm.controller" /> <!--避免IE执行AJAX时,返回JSON出现下载文件 --> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <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>mybatis对应的映射文件可以参考/article/11063307.html这里面讲了mybatis自动生成映射文件方法。
IUserService.java内容:
package com.project.ssm.service; import java.util.List; import com.project.ssm.entity.User; public interface IUserService { public User getUserById(int userId); public void addUser(User user); public List<User> getUserList(); }UserServiceImpl.java内容:
package com.project.ssm.service.Impl; import java.util.List; import javax.annotation.Resource; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.project.ssm.dao.IUserDao; import com.project.ssm.entity.User; import com.project.ssm.service.IUserService; @Service public class UserServiceImpl implements IUserService { @Resource private IUserDao userDao; /** * 根据id查询用户 */ @Override public User getUserById(int userId) { return userDao.selectByPrimaryKey(userId); } /** * 添加用户 */ @Override public void addUser(User user) { userDao.insert(user); } /** * 用户列表 */ @Override public List<User> getUserList() { return userDao.selectAllUser(); } }UserController.java控制器内容:
package com.project.ssm.controller; import java.util.List; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import com.project.ssm.entity.User; import com.project.ssm.service.IUserService; @Controller @RequestMapping("/user") public class UserController { @Resource private IUserService userService; /** * 根据id查询指定用户 * @param request * @param model * @return */ @RequestMapping("/showUser") public String showUser(HttpServletRequest request,Model model){ int userId = Integer.parseInt(request.getParameter("id")); User user = this.userService.getUserById(userId); model.addAttribute("user", user); System.out.println(user.toString()); return "showUser"; } /** * 用户列表 * @param request * @param model * @return */ @RequestMapping("/userList") public String userList(HttpServletRequest request,Model model){ List<User> list = this.userService.getUserList(); model.addAttribute("userlist", list); return "userlist"; } }界面view:
userlist.jsp内容如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>用户列表</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <table width="500px" border="1px"> <thead> <tr> <th>ID</th> <th>用户名</th> <th>密码</th> </tr> </thead> <tbody> <c:forEach var="user" items="${ userlist }"> <tr> <td><c:out value="${ user.id }"></c:out></td> <td><c:out value="${ user.username }"></c:out></td> <td><c:out value="${ user.password }"></c:out></td> </tr> </c:forEach> </tbody> </table> </body> </html>showUser.jsp内容如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>用户列表</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> ${user.username} <br> ${user.password} </body> </html>
运行地址:http://localhost:8080/SSM/user/showUser.do?id=1
运行地址:http://localhost:8080/SSM/user/userList.do
整合完毕。
源码下载地址:http://download.csdn.net/detail/gaoxuaiguoyi/9431979
相关文章推荐
- Eclipse反编译工具Jad及插件JadClipse配置
- Java通过Zxing生成二维码
- Java认证考试实例疑难辨析(9)
- JAVA内存参数配置
- java序列化,反序列化及反序列如何判断是否已读到文件末尾
- 02Mac下编译java代码
- Android的eclipse插件adt无法启动“No target available”
- hbase java api 使用demo
- 关于Java线程状态
- Java中String类的isEmpty方法、null以及""的区别
- java加密与解密的艺术 -- 笔记
- java线程间的通信
- java import javax.mail.*报错原因
- java注解
- JavaWeb实现文件上传与下载实例详解
- zookeeper学习-3(如何使用zookeeper进行集群管理-java版本)
- Android Studio如何更改JDK和SDK的路径?
- java 23种设计模式
- Java version 32转64位
- EJB--SessionBean