本文記錄了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-scan base-package="org.jisonami.controller">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!-- 配置springmvc的視圖解析器 -->
<bean id="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-scan base-package="org.jisonami">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
5、關于spring配置文件中的xml頭部:
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"
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
private UserService userService;
三、Spring與MyBatis的整合
1、MyBatis的使用主要是使用Mapper接口+Mapper.xml中寫sql的方式來實現更靈活的dao層,這一部分在與spring整合之后是不變的
而mybatis的全局配置文件則是SqlMapConfig.xml,也可以是其它的名字。
2、整合之前,數據庫的連接信息是在SqlMapConfig.xml中配置的,并且Mapper的掃描也是在SqlMapConfig.xml中配置的
最麻煩的是我們完成crud操作的代碼有比較多的冗余,即如下所示的形式:
Java代碼
// 完成一個新增操作
InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
SqlSession session = sessionFactory.openSession();
UserMapper userMapper = 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-placeholder location="classpath:DBConfig.properties"/>
<!-- 配置數據源,使用c3p0連接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<property name="driverClass" value="${jdbc.driver}"></property>
<property name="jdbcUrl" value="${jdbc.url}"></property>
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.pass}"></property>
</bean>
<!-- 配置sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:SqlMapConfig.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 掃描mapper接口 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="org.jisonami.mybatis.mapper"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
5、原來的SqlMapConfig.xml文件中只剩下寥寥幾行配置信息,
Xml代碼
<configuration>
<!-- 給entity起別名,在mapper配置文件中寫sql語句時會用到 -->
<typeAliases>
<package name="org.jisonami.entity"/>
</typeAliases>
</configuration>
6、以UserMapper.xml配置片段為例,描述整合后的簡潔編程方式
Xml代碼
<!-- mapper的命名空間namespace是Mapper接口的全限定名 -->
<mapper namespace="org.jisonami.mybatis.mapper.UserMapper">
<!-- id是唯一標識符,與Mapper接口的方法名保持一致,參數類型parameterType是參數類型的全限定名,這里使用的是別名 -->
<insert id="save" parameterType="User">
<selectKey keyColumn="id" keyProperty="id" resultType="String" order="BEFORE">
select sys_guid() from dual
</selectKey>
insert into t_user(id, name, password) values(#{id}, #{name}, #{password})
</insert>
</mapper>
UserMapper接口中的方法聲明如下:
Java代碼
public interface UserMapper {
public void save(User user);
}
調用部分代碼,直接注入UserMapper
Java代碼
@Autowired
private UserMapper userMapper;
public void save(User user) {
userMapper.save(user);
}
獲取【下載地址】 【免費支持更新】
三大數據庫 mysql oracle sqlsever 更專業、更強悍、適合不同用戶群體
【新錄針對本系統的視頻教程,手把手教開發一個模塊,快速掌握本系統】
A 集成代碼生成器 [正反雙向(單表、主表、明細表、樹形表,開發利器)+快速構建表單;
freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本,處理類,service等完整模塊
B 集成阿里巴巴數據庫連接池druid;
數據庫連接池 阿里巴巴的 druid。Druid在監控、可擴展性、穩定性和性能方面都有明顯的優勢
C 集成安全權限框架shiro ;
Shiro 是一個用 Java 語言實現的框架,通過一個簡單易用的 API 提供身份驗證和授權,更安全,更可靠
D 集成ehcache 分布式緩存 ;
是一個純Java的進程內緩存框架,具有快速、精干等特點,廣泛使用的開源Java分布式緩存。
E 集成微信接口開發; F 圖片爬蟲技術; G SQL 編輯器, 支持復雜sql語句,生成報表,可以導出excel;
H websocket及時通訊技術;(即時聊天、及時站內信并聲音提醒、實時在線管理、websocket及時刷新頁面);
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。