Spring+SpringMVC+MyBatis+Maven框架整合
本文记录了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及时刷新页面);
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。