本文記錄了Spring+SpringMVC+MyBatis+Maven框架整合的記錄,主要記錄以下幾點?
一、Maven需要引入的jar包?
二、Spring與SpringMVC的配置分離?
三、Spring與MyBatis的整合?

一、Maven需要引入的jar包?
本文默認讀者已經掌握Maven的使用,Maven配置片段如下?

Xml代碼??收藏代碼

  1. <!--?引入spring-webmvc與spring-jdbc?-->??

  2. <dependency>??

  3. Spring框架很難么?????<groupId>org.springframework</groupId>??

  4. ????<artifactId>spring-webmvc</artifactId>??

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

  6. </dependency>??

  7. <dependency>??

  8. maven jar,????<groupId>org.springframework</groupId>??

  9. ????<artifactId>spring-jdbc</artifactId>??

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

  11. </dependency>??

  12. <!--?引入mybatis與mybatis-spring整合包?-->??

  13. idea整合maven?<dependency>??

  14. ????<groupId>org.mybatis</groupId>??

  15. ????<artifactId>mybatis</artifactId>??

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

  17. </dependency>??

  18. Mybatis框架。<dependency>??

  19. ????<groupId>org.mybatis</groupId>??

  20. ????<artifactId>mybatis-spring</artifactId>??

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

  22. </dependency>??

  23. Spring boot、<!--?引入oracle數據庫jdbc驅動包?-->??

  24. <dependency>??

  25. ????<groupId>com.oracle</groupId>??

  26. ????<artifactId>ojdbc14</artifactId>??

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

  28. spring開發框架。</dependency>??

  29. <!--?引入c3p0連接池依賴包?-->??

  30. <dependency>??

  31. ????<groupId>c3p0</groupId>??

  32. ????<artifactId>c3p0</artifactId>??

  33. SpringMVC框架、????<version>${c3p0.version}</version>??

  34. </dependency>??



二、Spring與SpringMVC的配置分離?

1、有必要說明一下,web.xml中配置的執行順序:?
listener>filter>servlet,而同一種配置片段則按照從上到下的順序執行。?

2、web.xml的配置片段,下面的配置信息將Spring與SpringMVC的配置分別放到了applicationContext*.xml和springmvc-servlet.xml?

Xml代碼??收藏代碼

  1. <!--?配置spring-web上下文監聽器?-->??

  2. spring整合了哪些框架、<listener>??

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

  4. </listener>??

  5. <!--?配置需要讀取的spring配置文件路徑?-->??

  6. <!--?classpath*表示讀取多個classpath?-->??

  7. 如何使用spring框架。<!--?applicationContext*表示匹配多個applicationContext開頭的spring配置文件?-->??

  8. <context-param>??

  9. ????<param-name>contextConfigLocation</param-name>??

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

  11. </context-param>??

  12. spring框架有什么用???

  13. <!--?配置springmvc的DispatcherServlet,處理所有.do結尾的url?-->??

  14. <servlet>??

  15. ????<servlet-name>springmvc</servlet-name>??

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

  17. ssm框架整合步驟,????<!--?配置springmvc的配置文件路徑?-->??

  18. ????<init-param>??

  19. ????????<param-name>contextConfigLocation</param-name>??

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

  21. ????</init-param>??

  22. Spring框架介紹及使用。</servlet>??

  23. <servlet-mapping>??

  24. ????<servlet-name>springmvc</servlet-name>??

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

  26. </servlet-mapping>??

  27. javaweb框架。??

  28. <!--?配置springmvc編碼攔截器?-->??

  29. <filter>??

  30. ????<filter-name>encodingFilter</filter-name>??

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

  32. ssh三大框架整合、????<init-param>??

  33. ????????<param-name>encoding</param-name>??

  34. ????????<param-value>utf-8</param-value>??

  35. ????</init-param>??

  36. ????<init-param>??

  37. javaspring框架。????????<param-name>forceEncoding</param-name>??

  38. ????????<param-value>true</param-value>??

  39. ????</init-param>??

  40. </filter>??

  41. <filter-mapping>??

  42. ????<filter-name>encodingFilter</filter-name>??

  43. ????<url-pattern>/*</url-pattern>??

  44. </filter-mapping>??



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

Xml代碼??收藏代碼

  1. <!--?自動掃描注解,只掃描的Controller注解,其它注解的掃描交給spring去處理?-->??

  2. <context:component-scan?base-package="org.jisonami.controller">??

  3. ????<context:include-filter?type="annotation"?expression="org.springframework.stereotype.Controller"/>??

  4. </context:component-scan>??

  5. <!--?配置springmvc的視圖解析器?-->??

  6. <bean?id="viewResolver"?class="org.springframework.web.servlet.view.InternalResourceViewResolver"??

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

  8. </bean>??


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

Xml代碼??收藏代碼

  1. <context:component-scan?base-package="org.jisonami">??

  2. ????<context:exclude-filter?type="annotation"?expression="org.springframework.stereotype.Controller"/>??

  3. </context:component-scan>??



5、關于spring配置文件中的xml頭部:?

Xml代碼??收藏代碼

  1. <?xml?version="1.0"?encoding="UTF-8"?>??

  2. <beans?xmlns="http://www.springframework.org/schema/beans"??

  3. ????xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"??

  4. ????xmlns:p="http://www.springframework.org/schema/p"??

  5. ????xmlns:context="http://www.springframework.org/schema/context"??

  6. ????xsi:schemaLocation="??

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

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

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

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



6、此時已經可以在代碼中使用注解來配置spring的bean了,即如下形式的代碼完成依賴注入:?

Java代碼??收藏代碼

  1. @Autowired??

  2. private?UserService?userService;??



三、Spring與MyBatis的整合?
1、MyBatis的使用主要是使用Mapper接口+Mapper.xml中寫sql的方式來實現更靈活的dao層,這一部分在與spring整合之后是不變的?
而mybatis的全局配置文件則是SqlMapConfig.xml,也可以是其它的名字。?

2、整合之前,數據庫的連接信息是在SqlMapConfig.xml中配置的,并且Mapper的掃描也是在SqlMapConfig.xml中配置的?
最麻煩的是我們完成crud操作的代碼有比較多的冗余,即如下所示的形式:?

Java代碼??收藏代碼

  1. //?完成一個新增操作??

  2. InputStream?is?=?Resources.getResourceAsStream("SqlMapConfig.xml");??

  3. SqlSessionFactory?sessionFactory?=?new?SqlSessionFactoryBuilder().build(is);??

  4. SqlSession?session?=?sessionFactory.openSession();??

  5. UserMapper?userMapper?=?session.getMapper(UserMapper.class);??

  6. userMapper.save(user);??

  7. session.commit();??

  8. session.close();??



3、與spring整合的目的則是將SqlSessionFactory、SqlSession、UserMapper的創建和SqlSession的事物提交與關閉交給spring容器進行管理,?
實現只需要調用一行代碼的效果,即?

Java代碼??收藏代碼

  1. userMapper.save(user);??



4、整合之后,數據庫的連接信息與Mapper的掃描的配置片段直接移到applicationContext.xml中去了,完成SqlSessionFactory、SqlSession、UserMapper注入?
applicationContext.xml中mybatis的配置片段:?

Xml代碼??收藏代碼

  1. <!--?mybatis與spring整合?-->??

  2. <!--?加載數據庫配置文件?-->??

  3. <context:property-placeholder?location="classpath:DBConfig.properties"/>??

  4. <!--?配置數據源,使用c3p0連接池?-->??

  5. <bean?id="dataSource"?class="com.mchange.v2.c3p0.ComboPooledDataSource"?destroy-method="close">??

  6. ????<property?name="driverClass"?value="${jdbc.driver}"></property>??

  7. ????<property?name="jdbcUrl"?value="${jdbc.url}"></property>??

  8. ????<property?name="user"?value="${jdbc.user}"></property>??

  9. ????<property?name="password"?value="${jdbc.pass}"></property>??

  10. </bean>??

  11. <!--?配置sqlSessionFactory?-->??

  12. <bean?id="sqlSessionFactory"?class="org.mybatis.spring.SqlSessionFactoryBean">??

  13. ????<property?name="configLocation"?value="classpath:SqlMapConfig.xml"?/>??

  14. ????<property?name="dataSource"?ref="dataSource"?/>??

  15. </bean>??

  16. <!--?掃描mapper接口?-->??

  17. <bean?class="org.mybatis.spring.mapper.MapperScannerConfigurer">??

  18. ????<property?name="basePackage"?value="org.jisonami.mybatis.mapper"></property>??

  19. ????<property?name="sqlSessionFactoryBeanName"?value="sqlSessionFactory"></property>??

  20. </bean>??



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

Xml代碼??收藏代碼

  1. <configuration>??

  2. ????<!--?給entity起別名,在mapper配置文件中寫sql語句時會用到?-->??

  3. ????<typeAliases>??

  4. ????????<package?name="org.jisonami.entity"/>??

  5. ????</typeAliases>??

  6. </configuration>??



6、以UserMapper.xml配置片段為例,描述整合后的簡潔編程方式?

Xml代碼??收藏代碼

  1. <!--?mapper的命名空間namespace是Mapper接口的全限定名?-->??

  2. <mapper?namespace="org.jisonami.mybatis.mapper.UserMapper">??

  3. ??

  4. ????<!--?id是唯一標識符,與Mapper接口的方法名保持一致,參數類型parameterType是參數類型的全限定名,這里使用的是別名?-->??

  5. ????<insert?id="save"?parameterType="User">??

  6. ????????<selectKey?keyColumn="id"?keyProperty="id"?resultType="String"?order="BEFORE">??

  7. ????????????select?sys_guid()?from?dual??

  8. ????????</selectKey>??

  9. ????????insert?into?t_user(id,?name,?password)?values(#{id},?#{name},?#{password})??

  10. ????</insert>??

  11. </mapper>??


UserMapper接口中的方法聲明如下:?

Java代碼??收藏代碼

  1. public?interface?UserMapper?{??

  2. ????public?void?save(User?user);??

  3. }??


調用部分代碼,直接注入UserMapper?

Java代碼??收藏代碼

  1. @Autowired??

  2. private?UserMapper?userMapper;??

  3. public?void?save(User?user)?{??

  4. ????userMapper.save(user);??

  5. }??


獲取【下載地址】? ?【免費支持更新】
三大數據庫 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及時刷新頁面);