溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringMVC + MyBatis整合 【轉(zhuǎn)】

發(fā)布時(shí)間:2020-08-05 15:15:20 來源:網(wǎng)絡(luò) 閱讀:289 作者:提交人體 欄目:數(shù)據(jù)庫

環(huán)境:spring3.1.1+mybatis3.2.8+mybatis-spring1.2.3

網(wǎng)絡(luò)上關(guān)于這個(gè)架構(gòu)的搭建文章,實(shí)在是太多了,本文是對(duì)于本人初次搭建時(shí)的一些注意點(diǎn)的整理。

主要是一些配置文件的內(nèi)容和架構(gòu)的目錄。

0. project 目錄

SpringMVC + MyBatis整合  【轉(zhuǎn)】

1. spring-resources.xml

這個(gè)文件是用來完成spring和mybatis的整合的xml。注意properties文件的讀入方式。

<?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"  
    xmlns:tx="http://www.springframework.org/schema/tx"  
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="  
    http://www.springframework.org/schema/beans   
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
    http://www.springframework.org/schema/tx   
    http://www.springframework.org/schema/tx/spring-tx-3.0.xsd   
    http://www.springframework.org/schema/context   
    http://www.springframework.org/schema/context/spring-context-3.0.xsd
    http://www.springframework.org/schema/aop        
    http://www.springframework.org/schema/aop/spring-aop-3.2.xsd" 
	default-autowire="byName" default-lazy-init="false">
	
	<!-- 自動(dòng)掃描組件,需要把controller去掉,否則影響事務(wù)管理 -->  
    <context:component-scan base-package="org.com.mars">  
        <context:exclude-filter type="regex"  
            expression="org.com.mars.controller.*" />  
    </context:component-scan>

	<!-- 引入jdbc配置文件 -->  
    <context:property-placeholder location="classpath:prop/jdbc.properties" /> 

	<!-- (事務(wù)管理)transaction manager, use JtaTransactionManager for global tx -->  
    <bean id="transactionManager"  
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
        <property name="dataSource" ref="dataSource" />  
    </bean> 
    
    <!-- 聲明式事務(wù)管理 -->
    <aop:config>  
        <aop:advisor pointcut="execution(* org.com.mars.service..*.*(..))"  
            advice-ref="myAdvice" />  
    </aop:config>  
    <tx:advice id="myAdvice" transaction-manager="transactionManager">  
        <tx:attributes>  
            <tx:method name="find*" propagation="SUPPORTS" read-only="true" />  
            <tx:method name="query*" propagation="SUPPORTS" read-only="true" />  
            <tx:method name="list*" propagation="SUPPORTS" read-only="true" />  
  
            <tx:method name="create*" propagation="REQUIRED" />  
            <tx:method name="save*" propagation="REQUIRED" />  
            <tx:method name="modify*" propagation="REQUIRED" />  
            <tx:method name="update*" propagation="REQUIRED" />  
            <tx:method name="delete*" propagation="REQUIRED" />  
  
            <tx:method name="*" propagation="SUPPORTS" read-only="true" />  
        </tx:attributes>  
    </tx:advice>  
    
    <!-- 創(chuàng)建SqlSessionFactory,同時(shí)指定數(shù)據(jù)源 -->  
    <bean id="mySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
        <property name="dataSource" ref="dataSource" />  
        <!-- 自動(dòng)掃描entity目錄, 省掉Configuration.xml里的手工配置 -->
        <property name="mapperLocations" value="classpath*:maper/*.map.xml" />
    </bean> 
    
    <!-- DAO接口所在包名,Spring會(huì)自動(dòng)查找其下的類 --> 
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
        <property name="basePackage" value="org.com.mars.dao" />
        <property name="sqlSessionFactoryBeanName" value="mySqlSessionFactory" />
    </bean>
    
    <!-- 可通過注解控制事務(wù) -->  
    <tx:annotation-driven />
    
    <!-- 數(shù)據(jù)庫連接池 -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
		destroy-method="close">
		<!-- Connection Info -->
		<property name="driverClassName" value="${jdbc.driver}" />
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />

		<!-- Connection Pooling Info -->
		<property name="maxActive" value="${dbcp.maxActive}" />
		<property name="maxIdle" value="${dbcp.maxIdle}" />
		<property name="defaultAutoCommit" value="false" />
		<!-- 配置間隔多久才進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接,單位是毫秒 -->
		<property name="timeBetweenEvictionRunsMillis" value="3600000" />
		<!-- 配置一個(gè)連接在池中最小生存的時(shí)間,單位是毫秒 -->
		<property name="minEvictableIdleTimeMillis" value="3600000" />
	</bean></beans>

2. mapper.xml

該xml 如何使用配置,請(qǐng)參看spring-resources.xml,注意mapper.xml中 namespace的配置。

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="org.com.mars.dao.test.UserDao">

 <!-- mapping -->
 <resultMap id="User_t" type="org.com.mars.pojo.test.User">
 <result property="userId" column="user_id" jdbcType="VARCHAR" />
 <result property="userName" column="user_name" jdbcType="VARCHAR" />
 </resultMap>

 <sql id="columns">
 user_id,
 user_name </sql>


 <!-- 根據(jù)ID查詢用戶信息 -->
 <select id="queryUserById" resultMap="User_t">
 SELECT <include refid="columns" />
 FROM
 user_t
 WHERE
 user_id = #{userId}
 </select></mapper>

springmvc + mybatis整合詳細(xì),及遇到的問題請(qǐng)參看以下資料:

1. 使用阿里巴巴Druid連接池(高效、功能強(qiáng)大、可擴(kuò)展性好的數(shù)據(jù)庫連接池、監(jiān)控?cái)?shù)據(jù)庫訪問性能、支持Common-Logging、Log4j和JdkLog,監(jiān)控?cái)?shù)據(jù)庫訪問)
2. 提供高并發(fā)JMS消息處理機(jī)制
3. 所有功能模塊化、所有模塊服務(wù)化、所有服務(wù)原子化的方式,提供可拓展的服務(wù)模型,使程序穩(wěn)定運(yùn)行,永不宕機(jī)
4. 提供Wink Rest、Webservice服務(wù),故可作為獨(dú)立服務(wù)平臺(tái)部署

框架整合:

Springmvc + Mybatis + Shiro(權(quán)限) + REST(服務(wù)) + WebService(服務(wù)) + JMS(消息) + Lucene(搜搜引擎) + Quartz(定時(shí)調(diào)度) + Bootstrap Html5(支持PC、IOS、Android)

框架簡(jiǎn)介:


項(xiàng)目Maven構(gòu)建,真實(shí)大型互聯(lián)網(wǎng)架構(gòu),做到高并發(fā),大數(shù)據(jù)處理,整個(gè)項(xiàng)目使用定制化服務(wù)思想,提供模塊化、服務(wù)化、原子化的方案,將功能模塊進(jìn)行拆分,可以公用到所有的項(xiàng)目中。架構(gòu)采用分布式部署架構(gòu),所有模塊進(jìn)行拆分,使項(xiàng)目做到絕對(duì)解耦,穩(wěn)定壓倒一切~~

持續(xù)集成:

1. 我的待辦工作流服務(wù)(提供Webservice服務(wù))

2. 我的待辦工作流集成JMS消息服務(wù)(支持高并發(fā),可支持成千上萬系統(tǒng)集成)

3. 我的任務(wù)提供Rest服務(wù),完成日常的工作管理,通過定時(shí)調(diào)度平臺(tái),動(dòng)態(tài)生成我的任務(wù)、循環(huán)周期任務(wù)、定時(shí)郵催提醒完成任務(wù)等

4. 文件上傳、多線程下載服務(wù)化、發(fā)送郵件、短信服務(wù)化、部門信息服務(wù)化、產(chǎn)品信息服務(wù)化、信息發(fā)布服務(wù)化、我的訂閱服務(wù)化、我的任務(wù)服務(wù)化、公共鏈接、我的收藏服務(wù)化等

系統(tǒng)模塊:

 1.  用戶管理:

      用戶信息管理(添加、刪除、修改、用戶授權(quán)、用戶欄目管理、查詢等)

      用戶組管理(添加、刪除、修改、用戶組欄目授權(quán),欄目授權(quán)、查詢、用戶組人員添加查詢等)

      用戶角色管理(添加、刪除、修改、用戶角色授權(quán)、用戶角色欄目信息查詢?cè)O(shè)置等)
 2.  文章管理:

      欄目管理:查詢無限極欄目樹、創(chuàng)建無限極欄目樹分類(導(dǎo)航欄目、圖片列表欄目、文章列表欄目、文章內(nèi)容欄目等)、刪除、修改欄目信息。

      文章管理:創(chuàng)建、刪除、修改文章,多維度文章查詢,包括已發(fā)布、未發(fā)布、所有文章等。文章富文本編輯器、文章多文件上傳、文章狀態(tài)控制等。
3.  系統(tǒng)設(shè)置:

       數(shù)據(jù)字典管理:支持中、英文信息,支持無限級(jí)別分類配置,動(dòng)態(tài)控制是否可用等。

       部門信息管理:支持中、英文無限級(jí)別部門信息增加,刪除,修改操作,部門列表、樹心查詢等。

       日志管理:系統(tǒng)日志列表查詢、在線查看、在線下載等

       路線管理:集成百度地圖API,提供線路查詢管理功能

       Druid Monitor(監(jiān)控):集成阿里巴巴連接池,提供在線連接池監(jiān)控程序,包括:數(shù)據(jù)源、SQL監(jiān)控、URL監(jiān)控、Session監(jiān)控、Spring監(jiān)控等

       網(wǎng)站信息管理:通過系統(tǒng)配置文件進(jìn)行網(wǎng)站內(nèi)容操作,包括郵件服務(wù)器配置、公司基本信息配置等。

 4.  集成REST服務(wù),可以用作獨(dú)立服務(wù)平臺(tái)(提供大量實(shí)例及測(cè)試平臺(tái),包括:文件上傳下載、郵件短信發(fā)送、部門、產(chǎn)品、公共連接、我的收藏、我的任務(wù)、信息發(fā)布等)

 5.  集成Quartz調(diào)度,可以用作定時(shí)調(diào)度平臺(tái)(動(dòng)態(tài)配置調(diào)度類、調(diào)度時(shí)間,使程序自動(dòng)執(zhí)行某些業(yè)務(wù))

 6.  Lucene搜索引擎,可以將文件資料索引化,支持文件內(nèi)容搜索、關(guān)鍵字搜索、高亮關(guān)鍵字等,使信息在毫秒內(nèi)提取查詢出來

 7.  用戶設(shè)置功能包括修改用戶信息,修改密碼、發(fā)送消息,修改個(gè)人圖片,查看角色、查看用戶組,管理員修改角色、用戶、用戶組等。

 8.  集成Webservice平臺(tái)包括jaxws服務(wù)、CXF框架,配置雙加密的權(quán)限認(rèn)證。使服務(wù)集成更加安全。

 9.  Bootstrap html5提供了兩套前臺(tái)開環(huán)境包括CMS和電子商務(wù)網(wǎng)站,使您的開發(fā)更加的簡(jiǎn)潔。

技術(shù)點(diǎn):

1.  Springmvc + Mybatis集成、SpringSecurity權(quán)限控制、Spring AOP事務(wù)處理。

2.   Wink Rest服務(wù)、Webservice服務(wù):jaxws、CXF等

3.  IO 流上傳下載文件,多線程操作

4.  發(fā)送郵件,配置郵件服務(wù)器,發(fā)基于html、純文本格式的郵件

5.  MD5加密 (登陸密碼校驗(yàn)加密等),用戶統(tǒng)一Session、Cookie管理,統(tǒng)一驗(yàn)證碼校驗(yàn)等。

6.  數(shù)據(jù)庫連接池統(tǒng)一配置 

7.  Quartz定時(shí)調(diào)度任務(wù)集成(直接通過配置即可)

8.  Httpclient破解驗(yàn)證碼,登陸聯(lián)通充值平臺(tái)

9.  漢字、英文拆分、可以用作文檔關(guān)鍵字搜索等。

10.  Base64圖片處理,支持PC,Android,IOS

11.  Service Socket 、Client Socket 通信技術(shù)(已經(jīng)做過GPRS數(shù)據(jù)獲取,并用到了項(xiàng)目中)

12.  提供大量工具類,可以直接使用

13.  Maven項(xiàng)目構(gòu)建,您可以直接做架構(gòu),可以提升自己的學(xué)習(xí)能力,使您成為真正的架構(gòu)師。


SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

 SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

SpringMVC + MyBatis整合  【轉(zhuǎn)】SpringMVC + MyBatis整合  【轉(zhuǎn)】

 SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 SpringMVC + MyBatis整合  【轉(zhuǎn)】
 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】

 

SpringMVC + MyBatis整合  【轉(zhuǎn)】


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI