本文记录使用Intellij创建Maven Web工程搭建Spring MVC + Mybatis 的一个非常简单的示例。关于Mybatis的入门使用可参考这篇文章,本文在该文的基础上,引入了Spring MVC功能。首先是创建项目:
打开Intellij,File-->new Project--->选中,Maven--->勾上"Create from archetype"--->选择 Maven web project。如下图:
一步步Next,等待工程Build成功,如果右下角有提示“Maven project need to be imported“则点击: import change...”
完了之后,整个项目Build Success,官网:www.fhadmin.org 会生成如下初始目录:
在src.main下新建一个文件夹 java, 作为源代码目录。CTRL+ALT+SHIFT+S 打开“project structure配置窗口”,将 java 目录关联成 source目录。
在 java 目录下创建四个子目录 controller、mapper、pojo、service
controller,控制器类。DispatcherServlet将拦截到的HTTP请求交给对应的Controller来处理,Controller调用 Service 完成相应的请求任务。
service,官网:www.fhadmin.org 业务逻辑实现类。Service 一般都需要DAO类(或者说Mapper类)操作数据库,然后完成相应的业务逻辑处理。
mapper,数据库操作类。定义了一些如何操作数据库的方法。
pojo,实体类。对应数据库中的表,一般pojo类中的每个属性对应数据库中的一个字段。
此外,还有配置文件目录。在 src/main/resources目录下,新建mapper文件夹,与 src/main/java/mapper 对应:一个RoleMapper.java 对应着一个 RoleMapper.xml配置文件,再加上相应的Spring配置就可以实现数据库的操作。在 src/main/resources目录下,新建spring文件夹,里面有三个配置文件:spring-web.xml是web相关配置;spring-dao.xml是数据库相关的配置;spring-service.xml是Service类相关的配置。当然也可以将所有的配置放在一个文件里,比如常见的applicationContext.xml,分开配置的话,可能看起来更清晰。大致目录结构如下:
POJO类 Role.java代码和数据库表t_role字段,参考这篇文章前面部分。RoleMapper.java 定义了操作数据库的方法--根据 id字段 来查找 Role,官网:www.fhadmin.org getRole方法配合RoleMapper.xml中定义的数据库操作语句,就可以由Mybatis框架来负责所有的数据库操作事宜了。代码如下:
package mapper; import org.springframework.stereotype.Repository; import pojo.Role; @Repository public interface RoleMapper { public Role getRole(long id); }
对应的RoleMapper.xml配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="mapper.RoleMapper">
<select id="getRole" parameterType="long" resultType="Role">
select id,
role_name as roleName, note from t_role where id = #{id}
</select>
</mapper>
官网:www.fhadmin.org 再来看业务逻辑,很简单:用户从浏览器中发一个查询请求 Role,请求的参数为 id,Service根据 id 去数据库找 Role 记录,返回给用户 id 对应的Role。
RoleService.java代码如下:
package service; import pojo.Role; /** * Created by Administrator on 2017/8/10. */ public interface RoleService { public Role getRole(long id); }
具体的实现类如下:
1 package service.impl; 2 3 import mapper.RoleMapper; 4 import org.springframework.beans.factory.annotation.Autowired; 5 import org.springframework.stereotype.Service; 6 import pojo.Role; 7 import service.RoleService; 8 9 /** 10 * Created by Administrator on 2017/8/10. 11 */ 12 @Service 13 public class RoleServiceImpl implements RoleService { 14 15 @Autowired 16 private RoleMapper roleMapper; 17 18 public Role getRole(long id){ 19 Role role = roleMapper.getRole(id); 20 return role; 21 } 22 }
第12行,@Service 以Spring注解的方式将RoleServiceImpl定义成Bean,在spring-service.xml中配置:component-scan,让Spring去扫描 service包下带有注解的类,告诉Spring容器 RoleService(Impl)类 是一个Bean对象。在其它类中就可以用 @Autowired 官网:www.fhadmin.org 将RoleService注入。
<!-- 扫描service包下所有使用注解的类型 --> <context:component-scan base-package="service" />
完整spring-sevice.xml配置文件:
RoleController.java代码如下:
1 package controller; 2 3 import org.springframework.beans.factory.annotation.Autowired; 4 import org.springframework.stereotype.Controller; 5 import org.springframework.web.bind.annotation.RequestMapping; 6 import org.springframework.web.bind.annotation.RequestParam; 7 import org.springframework.web.bind.annotation.ResponseBody; 8 import pojo.Role; 9 import service.RoleService; 10 11 /** 12 * Created by Administrator on 2017/8/10. 13 */ 14 @Controller 15 public class RoleController { 16 @Autowired 17 private RoleService roleService; 18 19 @RequestMapping("/role/getRole") 20 @ResponseBody public Role getRole(@RequestParam("id") long id) 21 { 22 long start = System.currentTimeMillis(); 23 Role role = roleService.getRole(id); 24 long end = System.currentTimeMillis(); 25 System.out.println(end-start); 26 return role; 27 } 28 }
14行,@Controller 以Spring注解的方式将 RoleController类定义为Spring容器可管理的Bean。
19行,在web.xml中配置了 servlet-mapping,当浏览器请求的URL带有"role/getRole"时,就会拦截请求将给 RoleController来处理。
20行,@ResponseBody定义了 处理之后的返回值,将 Role 对象以 JSON格式封装起来,返回给浏览器。@RequestParam("id"),定义请求参数。
比如在浏览器中输入:http://localhost:8000/mvc/role/getRole?id=5
数据库中记录如下:
这一切到底是如何得到的呢?
①RoleController需要一个RoleService对象,然后在第23行调用 getRole方法,返回一个Role对象。首先第16-17行,使用 @Autowired将 RoleService注入到RoleController中,这样RoleController不需要显示地new RoleService对象,对应的创建过程由Spring容器自动完成----对象的创建 与 “对象的使用” 解耦。“对象的使用其实就是业务逻辑,让开发者不需要关注对象的创建了”
②为什么Spring容器知道 将 RoleService 作为一个Bean注入到 RoleController中去呢?
因为,RoleService类使用 了@Service 注解,并且在spring-service.xml中配置 了<component-scan....> 见上面RoleService源代码部分。
③为什么 roleSevice.getRole(id)就能从数据库中查找相应的记录并返回呢?前面的RoleMapper.java 和 RoleMapper.xml配置文件已经定义好了操作数据库的语句:
select id,role_name as roleName, note from t_role where id = #{id}
然后我们又在spring-dao.xml中配置了访问数据库:详细具体解释如下:
<context:component-scan base-package="mapper"/>
告诉Spring容器扫描mapper目录下的 带注解的类,这样RoleService就可以自动注入 RoleMapper对象了,有了RoleMapper对象,通过Mybatis框架,就可以访问数据库了。而Spring与Mybatis的整合依赖包,就需要在pom.xml中给出:
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.0</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.0</version>
</dependency>
<context:property-placeholder location="classpath:jdbc.properties"/>
配置数据库连接信息:访问哪个数据库?数据库地址在哪?访问数据库的端口是什么?用户名和密码是什么?这些信息都在jdbc.properties文件中定义好了,<context:property-placeholder>告诉Spring容器去哪里读取jdbc.properties配置文件。jdbc.properties文件如下:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test
jdbc.username=root
jdbc.password=xxxxx
知道了数据库在哪里了,以何种方式连接数据库呢?一般会配置各种连接池
<!-- 2.数据库连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<!-- 配置连接池属性 -->
<property name="driverClass" value="${jdbc.driver}"/>
<property name="jdbcUrl" value="${jdbc.url}"/>
<property name="user" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<!-- c3p0连接池的私有属性 -->
<property name="maxPoolSize" value="30"/>
<property name="minPoolSize" value="10"/>
<!-- 关闭连接后不自动commit -->
<property name="autoCommitOnClose" value="false"/>
<!-- 获取连接超时时间 -->
<property name="checkoutTimeout" value="10000"/>
<!-- 当获取连接失败重试次数 -->
<property name="acquireRetryAttempts" value="2"/>
</bean>
连接池的依赖包,又在哪里呢?因为我们使用的是Maven POM管理依赖,在pom.xml文件中就需要配置:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.37</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>c3p0</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.1.2</version>
</dependency>
配置好了访问数据库的环境,还需要访问数据库的具体实例,这就是SqlSession。于是继续在spring-dao.xml添加配置:
<!-- 3.配置SqlSessionFactory对象 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 注入数据库连接池 --> <property name="dataSource" ref="dataSource"/> <!-- 配置MyBaties全局配置文件:mybatisConfig.xml --> <property name="configLocation" value="classpath:mybatisConfig.xml"/> <!-- 扫描entity包 使用别名 --> <property name="typeAliasesPackage" value="pojo"/> <!-- 扫描sql配置文件:mapper需要的xml文件 --> <property name="mapperLocations" value="classpath:mapper/*.xml"/> </bean>
接下来再把SqlSession 告诉RoleMapper对象,让它拿着SqlSession去操作数据库。
<!-- 4.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 注入sqlSessionFactory --> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> <!-- 给出需要扫描mapper接口包 --> <property name="basePackage" value="mapper"/> </bean>
因此,这也是为什么 我们只需要通过Spring将RoleMapper能够访问数据库的原因。而当 Service需要访问数据库时,只需要将RoleMapper注入进来,就可以执行getRole方法查询数据库了。
完整的spring-dao.xml配置文件:
前面介绍的都是Spring应用上下文,而这里的 HTTP请求牵涉到 web应用上下文,二者是如何结合的呢?在web.xml中进行配置:
<servlet> <servlet-name>mvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 配置springMVC需要加载的配置文件 spring-dao.xml,spring-service.xml,spring-web.xml Mybatis - > spring -> springmvc --> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/spring-*.xml</param-value> </init-param> </servlet>
通过contextConfigLocation将 spring上下文中的配置文件加载进来,实现二者的结合。
发起请求--->请求拦截--->返回请求 是如何实现的呢?在web.xml中配置了servlet-mapping,其中的<servlet-name>mvc</servlet-name>这也是请求URL中 有 mvc 前缀的原因。<url-pattern>将匹配的请求交给DispatcherServlet,由DispatcherServlet转发给相应的 Controller,在RoleController.java中使用 @RequestMapping配置了 请求的路径role/getRole,这样 http://localhost:8000/mvc/role/getRole?id=5 就会交给RoleController来处理了。
最后,还需要启动web应用程序,在 pom.xml中配置 jetty 容器,来运行web应用:
<!-- jetty插件 --> <plugin> <groupId>org.mortbay.jetty</groupId> <artifactId>maven-jetty-plugin</artifactId> <version>6.1.25</version> <configuration> <connectors> <connector implementation="org.mortbay.jetty.nio.SelectChannelConnector"> <port>8000</port> <maxIdleTime>60000</maxIdleTime> </connector> </connectors> <contextPath>/mvc</contextPath> <scanIntervalSeconds>0</scanIntervalSeconds> </configuration> </plugin>
就可以在IDEA右侧,maven project中点击 jetty run 来运行了。
附完整的:mybatisConfig.xml
spring-web.xml
pom.xml配置文件
RoleService的调试:
在src目录下,新建 test 文件夹,用来作测试目录。然后在test目录下,建一个java目录,并将该目录关联为 “测试目录”。然后,在java目录下,src/main/java 一 一 对应的文件夹,作为mapper、controller、service类的测试类存放的文件夹。
比如,对RoleService进行测试如下:
package service; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import pojo.Role; /** * Created by Administrator on 2017/8/12. */ public class RoleServiceImplTest { public static void main(String[] args) { ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/spring-service.xml"); RoleService roleService = (RoleService) applicationContext.getBean(RoleService.class); Role role = roleService.getRole(5); System.out.println(role); } }
或者使用 TestNg等测试工具进行测试。
相关推荐
这份文档名为《Java EE 框架整合开发入门到实战——Spring+Spring MVC+MyBatis(微课版)课后习题答案.pdf》,它显然是关于Java EE中流行的三个框架整合使用的教程。这三个框架分别是Spring、Spring MVC和MyBatis,...
此外,了解Spring框架整合MyBatis及Spring MVC的细节,对于开发基于Java EE的企业级应用非常关键。Spring MVC负责Web层的请求处理,MyBatis则是持久层框架,能够简化数据库操作。熟练掌握这些框架的整合使用,能够...
该项目为Java EE框架整合开发实战教程,以Spring、Spring MVC和MyBatis为核心,提供600分钟的高质量教学视频、70个学习实例和3个完整项目案例。源码包含1085个文件,包括200个Java源文件、138个XML配置文件、72个JSP...
【标题】"Spring MVC+MyBatis项目代码"是一个针对初学者的实践教程,它结合了两种主流的Java Web开发框架——Spring MVC和MyBatis,以帮助学习者理解如何在实际项目中整合这两个框架。Spring MVC是Spring框架的一...
将 Spring MVC 与 MyBatis 整合,通常我们需要以下步骤: 1. **引入依赖**:在项目中添加 Spring MVC 和 MyBatis 相关的 Maven 或 Gradle 依赖。 2. **配置 Spring**:创建 Spring 配置文件,配置 ...
SSM(Spring、SpringMVC和MyBatis)整合是Java Web开发中常见的技术栈,它结合了Spring框架的强大功能,SpringMVC的优雅请求处理,以及MyBatis的灵活数据库操作。本项目是一个入门级别的实例,旨在帮助初学者理解和...
本项目是关于"activiti+spring+spring Mvc+mybatis+maven"的整合,旨在创建一个基于Activiti工作流引擎、Spring、Spring MVC、MyBatis以及Maven的开发环境。下面将详细介绍这些技术及其整合过程。 首先,`activiti`...
本篇文章将通过一个简单显示用户信息的实例整合Spring mvc+mybatis+Maven+velocity+mysql. 一、.Maven工程目录 二、Spring mvc + mybatis +maven实现 1.Mysql数据库表数据
在本实例中,我们将探讨如何将Spring MVC框架与MyBatis持久层框架进行整合,以构建一个基础的Web应用程序。Spring MVC提供了强大的模型-视图-控制器架构,而MyBatis则是一个轻量级的SQL映射框架,使得数据库操作更为...
3. MyBatis入门:XML配置文件、Mapper接口、动态SQL、一对一、一对多、多对多关联映射等。 4. SSM整合:配置文件编写、Spring管理MyBatis、事务配置、日志处理等。 5. 实战案例:创建一个完整的SSM项目,包括用户...
3. **MyBatis入门**:介绍MyBatis的配置、Mapper接口、XML映射文件和注解方式的使用。 4. **Spring MVC与MyBatis整合**:如何将两者结合,实现数据访问层(DAO)和业务服务层(Service)的设计。 5. **实战案例**:...
4. **Spring与MyBatis整合**:Spring MyBatis教程会讲解如何将Spring的依赖注入和事务管理与MyBatis的SQL映射相结合,实现更灵活的数据访问。这包括配置MyBatis的SqlSessionFactory,创建Mapper接口,以及使用`@...
《Spring4+Mybatis3+SpringMVC4实战》是一个基于这三个流行开源框架构建的完整项目,旨在帮助学习者深入理解和实践SSM(Spring、SpringMVC、Mybatis)架构。这个项目涵盖了从基础配置到高级特性的全方位应用,对于...
Mybatis与Spring的整合主要是在Spring的配置文件中配置数据源、SqlSessionFactoryBean等,从而整合Mybatis的SqlSession到Spring的ioc容器中。整合后的Mybatis可以享受Spring的事务管理能力,并且可以使用Spring的...
《Spring+MVC+MYBatis企业应用实战》是一本深度解析如何在企业环境中整合并高效使用这三大Java技术的指南。Spring作为一款强大的轻量级框架,提供了依赖注入、AOP(面向切面编程)等功能,极大地简化了Java开发。而...
此项目为springmvc、Mybatis、EHcache、maven、Spring security3、activiti5工作流的整合 是一个基于数据库的权限管理demo项目、使用mysql数据库 项目运行前需要构建maven私服 而且有些jar包私服中肯定没有,需要...
- Mybatis:Spring通过整合Mybatis,提供了SqlSessionFactoryBean和SqlSessionTemplate等组件,允许开发者在Spring环境中使用Mybatis。整合后,可以在Spring配置文件中配置数据源,然后通过SqlSessionFactoryBean...
"第6章 MyBatis入门.ppt"是入门教程,介绍MyBatis的基本配置和SQL映射文件的编写。"第7章 基于MyBatis的增删改查操作.ppt"会深入讲解如何执行CRUD操作,包括动态SQL的使用。"第9章 使用MyBatis动态代理技术实现DAO...
【Spring MVC 入门教程:整合 Mybatis 与 Oracle 实现简单查询】 在这个教程中,我们将探讨如何使用 Spring MVC 框架与 Mybatis ORM 工具,以及 Oracle 数据库来构建一个简单的查询功能。Spring MVC 是 Spring 框架...