本文記錄了Spring+SpringMVC+MyBatis+Maven框架整合的記錄,主要記錄以下幾點?
一、Maven需要引入的jar包?
二、Spring與SpringMVC的配置分離?
三、Spring與MyBatis的整合?
一、Maven需要引入的jar包?
本文默認讀者已經掌握Maven的使用,Maven配置片段如下?
Xml代碼??
<!--?引入spring-webmvc與spring-jdbc?-->??
<dependency>??
Spring框架很難么?????<groupId>org.springframework</groupId>??
????<artifactId>spring-webmvc</artifactId>??
????<version>${springframework.version}</version>??
</dependency>??
<dependency>??
maven jar,????<groupId>org.springframework</groupId>??
????<artifactId>spring-jdbc</artifactId>??
????<version>${springframework.version}</version>??
</dependency>??
<!--?引入mybatis與mybatis-spring整合包?-->??
idea整合maven?<dependency>??
????<groupId>org.mybatis</groupId>??
????<artifactId>mybatis</artifactId>??
????<version>${mybatis.version}</version>??
</dependency>??
Mybatis框架。<dependency>??
????<groupId>org.mybatis</groupId>??
????<artifactId>mybatis-spring</artifactId>??
????<version>${mybatis-spring.version}</version>??
</dependency>??
Spring boot、<!--?引入oracle數據庫jdbc驅動包?-->??
<dependency>??
????<groupId>com.oracle</groupId>??
????<artifactId>ojdbc14</artifactId>??
????<version>${oracle14.version}</version>??
spring開發框架。</dependency>??
<!--?引入c3p0連接池依賴包?-->??
<dependency>??
????<groupId>c3p0</groupId>??
????<artifactId>c3p0</artifactId>??
SpringMVC框架、????<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上下文監聽器?-->??
spring整合了哪些框架、<listener>??
????<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>??
</listener>??
<!--?配置需要讀取的spring配置文件路徑?-->??
<!--?classpath*表示讀取多個classpath?-->??
如何使用spring框架。<!--?applicationContext*表示匹配多個applicationContext開頭的spring配置文件?-->??
<context-param>??
????<param-name>contextConfigLocation</param-name>??
????<param-value>classpath*:applicationContext*.xml</param-value>??
</context-param>??
spring框架有什么用???
<!--?配置springmvc的DispatcherServlet,處理所有.do結尾的url?-->??
<servlet>??
????<servlet-name>springmvc</servlet-name>??
????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>??
ssm框架整合步驟,????<!--?配置springmvc的配置文件路徑?-->??
????<init-param>??
????????<param-name>contextConfigLocation</param-name>??
????????<param-value>classpath:springmvc-servlet.xml</param-value>??
????</init-param>??
Spring框架介紹及使用。</servlet>??
<servlet-mapping>??
????<servlet-name>springmvc</servlet-name>??
????<url-pattern>*.do</url-pattern>??
</servlet-mapping>??
javaweb框架。??
<!--?配置springmvc編碼攔截器?-->??
<filter>??
????<filter-name>encodingFilter</filter-name>??
????<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>??
ssh三大框架整合、????<init-param>??
????????<param-name>encoding</param-name>??
????????<param-value>utf-8</param-value>??
????</init-param>??
????<init-param>??
javaspring框架。????????<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及時刷新頁面);