本文记录了Spring+SpringMVC+MyBatis+Maven框架整合的记录,主要记录以下几点
一、Maven需要引入的jar包
二、Spring与SpringMVC的配置分离
三、Spring与MyBatis的整合

一、Maven需要引入的jar包
本文默认读者已经掌握Maven的使用,Maven配置片段如下

Xml代码

<!--引入spring-webmvc与spring-jdbc-->

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-webmvc</artifactId>

<version>${springframework.version}</version>

</dependency>

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-jdbc</artifactId>

<version>${springframework.version}</version>

</dependency>

<!--引入mybatis与mybatis-spring整合包-->

<dependency>

<groupId>org.mybatis</groupId>

<artifactId>mybatis</artifactId>

<version>${mybatis.version}</version>

</dependency>

<dependency>

<groupId>org.mybatis</groupId>

<artifactId>mybatis-spring</artifactId>

<version>${mybatis-spring.version}</version>

</dependency>

<!--引入oracle数据库jdbc驱动包-->

<dependency>

<groupId>com.oracle</groupId>

<artifactId>ojdbc14</artifactId>

<version>${oracle14.version}</version>

</dependency>

<!--引入c3p0连接池依赖包-->

<dependency>

<groupId>c3p0</groupId>

<artifactId>c3p0</artifactId>

<version>${c3p0.version}</version>

</dependency>



二、Spring与SpringMVC的配置分离

1、有必要说明一下,web.xml中配置的执行顺序:
listener>filter>servlet,而同一种配置片段则按照从上到下的顺序执行。

2、web.xml的配置片段,下面的配置信息将Spring与SpringMVC的配置分别放到了applicationContext*.xml和springmvc-servlet.xml

Xml代码

<!--配置spring-web上下文监听器-->

<listener>

<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

</listener>

<!--配置需要读取的spring配置文件路径-->

<!--classpath*表示读取多个classpath-->

<!--applicationContext*表示匹配多个applicationContext开头的spring配置文件-->

<context-param>

<param-name>contextConfigLocation</param-name>

<param-value>classpath*:applicationContext*.xml</param-value>

</context-param>

<!--配置springmvc的DispatcherServlet,处理所有.do结尾的url-->

<servlet>

<servlet-name>springmvc</servlet-name>

<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

<!--配置springmvc的配置文件路径-->

<init-param>

<param-name>contextConfigLocation</param-name>

<param-value>classpath:springmvc-servlet.xml</param-value>

</init-param>

</servlet>

<servlet-mapping>

<servlet-name>springmvc</servlet-name>

<url-pattern>*.do</url-pattern>

</servlet-mapping>

<!--配置springmvc编码拦截器-->

<filter>

<filter-name>encodingFilter</filter-name>

<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>

<init-param>

<param-name>encoding</param-name>

<param-value>utf-8</param-value>

</init-param>

<init-param>

<param-name>forceEncoding</param-name>

<param-value>true</param-value>

</init-param>

</filter>

<filter-mapping>

<filter-name>encodingFilter</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>



3、springmvc的配置片段如下,springmvc-servlet.xml

Xml代码

<!--自动扫描注解,只扫描的Controller注解,其它注解的扫描交给spring去处理-->

<context:component-scanbase-package="org.jisonami.controller">

<context:include-filtertype="annotation"expression="org.springframework.stereotype.Controller"/>

</context:component-scan>

<!--配置springmvc的视图解析器-->

<beanid="viewResolver"class="org.springframework.web.servlet.view.InternalResourceViewResolver"

p:prefix="/WEB-INF/content/"p:suffix=".jsp">

</bean>


4、目前本例中只是用了一个spring配置文件,即applicationContext.xml,如下:
<!-- 自动扫描spring注解,排除springmvc已扫描的Controller注解 -->

Xml代码

<context:component-scanbase-package="org.jisonami">

<context:exclude-filtertype="annotation"expression="org.springframework.stereotype.Controller"/>

</context:component-scan>



5、关于spring配置文件中的xml头部:

Xml代码

<?xmlversion="1.0"encoding="UTF-8"?>

<beansxmlns="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"

xsi:schemaLocation="

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context

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



6、此时已经可以在代码中使用注解来配置spring的bean了,即如下形式的代码完成依赖注入:

Java代码

@Autowired

privateUserServiceuserService;



三、Spring与MyBatis的整合
1、MyBatis的使用主要是使用Mapper接口+Mapper.xml中写sql的方式来实现更灵活的dao层,这一部分在与spring整合之后是不变的
而mybatis的全局配置文件则是SqlMapConfig.xml,也可以是其它的名字。

2、整合之前,数据库的连接信息是在SqlMapConfig.xml中配置的,并且Mapper的扫描也是在SqlMapConfig.xml中配置的
最麻烦的是我们完成crud操作的代码有比较多的冗余,即如下所示的形式:

Java代码

//完成一个新增操作

InputStreamis=Resources.getResourceAsStream("SqlMapConfig.xml");

SqlSessionFactorysessionFactory=newSqlSessionFactoryBuilder().build(is);

SqlSessionsession=sessionFactory.openSession();

UserMapperuserMapper=session.getMapper(UserMapper.class);

userMapper.save(user);

session.commit();

session.close();



3、与spring整合的目的则是将SqlSessionFactory、SqlSession、UserMapper的创建和SqlSession的事物提交与关闭交给spring容器进行管理,
实现只需要调用一行代码的效果,即

Java代码

userMapper.save(user);



4、整合之后,数据库的连接信息与Mapper的扫描的配置片段直接移到applicationContext.xml中去了,完成SqlSessionFactory、SqlSession、UserMapper注入
applicationContext.xml中mybatis的配置片段:

Xml代码

<!--mybatis与spring整合-->

<!--加载数据库配置文件-->

<context:property-placeholderlocation="classpath:DBConfig.properties"/>

<!--配置数据源,使用c3p0连接池-->

<beanid="dataSource"class="com.mchange.v2.c3p0.ComboPooledDataSource"destroy-method="close">

<propertyname="driverClass"value="${jdbc.driver}"></property>

<propertyname="jdbcUrl"value="${jdbc.url}"></property>

<propertyname="user"value="${jdbc.user}"></property>

<propertyname="password"value="${jdbc.pass}"></property>

</bean>

<!--配置sqlSessionFactory-->

<beanid="sqlSessionFactory"class="org.mybatis.spring.SqlSessionFactoryBean">

<propertyname="configLocation"value="classpath:SqlMapConfig.xml"/>

<propertyname="dataSource"ref="dataSource"/>

</bean>

<!--扫描mapper接口-->

<beanclass="org.mybatis.spring.mapper.MapperScannerConfigurer">

<propertyname="basePackage"value="org.jisonami.mybatis.mapper"></property>

<propertyname="sqlSessionFactoryBeanName"value="sqlSessionFactory"></property>

</bean>



5、原来的SqlMapConfig.xml文件中只剩下寥寥几行配置信息,

Xml代码

<configuration>

<!--给entity起别名,在mapper配置文件中写sql语句时会用到-->

<typeAliases>

<packagename="org.jisonami.entity"/>

</typeAliases>

</configuration>



6、以UserMapper.xml配置片段为例,描述整合后的简洁编程方式

Xml代码

<!--mapper的命名空间namespace是Mapper接口的全限定名-->

<mappernamespace="org.jisonami.mybatis.mapper.UserMapper">

<!--id是唯一标识符,与Mapper接口的方法名保持一致,参数类型parameterType是参数类型的全限定名,这里使用的是别名-->

<insertid="save"parameterType="User">

<selectKeykeyColumn="id"keyProperty="id"resultType="String"order="BEFORE">

selectsys_guid()fromdual

</selectKey>

insertintot_user(id,name,password)values(#{id},#{name},#{password})

</insert>

</mapper>


UserMapper接口中的方法声明如下:

Java代码

publicinterfaceUserMapper{

publicvoidsave(Useruser);

}


调用部分代码,直接注入UserMapper

Java代码

@Autowired

privateUserMapperuserMapper;

publicvoidsave(Useruser){

userMapper.save(user);

}


获取【下载地址】 【免费支持更新】
三大数据库 mysqloraclesqlsever 更专业、更强悍、适合不同用户群体
【新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统】

A 集成代码生成器 [正反双向(单表、主表、明细表、树形表,开发利器)+快速构建表单;
freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面、建表sql脚本,处理类,service等完整模块
B 集成阿里巴巴数据库连接池druid;
数据库连接池阿里巴巴的 druid。Druid在监控、可扩展性、稳定性和性能方面都有明显的优势
C 集成安全权限框架shiro ;
Shiro 是一个用 Java 语言实现的框架,通过一个简单易用的 API 提供身份验证和授权,更安全,更可靠
D 集成ehcache 分布式缓存 ;
是一个纯Java的进程内缓存框架,具有快速、精干等特点,广泛使用的开源Java分布式缓存。
E 集成微信接口开发; F 图片爬虫技术; GSQL 编辑器, 支持复杂sql语句,生成报表,可以导出excel;
H websocket及时通讯技术;(即时聊天、及时站内信并声音提醒、实时在线管理、websocket及时刷新页面);