SSM整合之使用配置類替換xml配置文件(2)

来源:https://www.cnblogs.com/lisong0626/p/18050751
-Advertisement-
Play Games

SSM整合就是將MVC三層架構和框架核心API組件交給SpringIoC容器管理! 一般需要配置兩個IoC容器進行三層架構組件管理。 容器名 盛放組件 web容器 web相關組件(controller,springmvc核心組件) root容器 業務和持久層相關組件(service,aop,tx,d ...


SSM整合就是將MVC三層架構和框架核心API組件交給SpringIoC容器管理!
一般需要配置兩個IoC容器進行三層架構組件管理。

容器名 盛放組件
web容器 web相關組件(controller,springmvc核心組件)
root容器 業務和持久層相關組件(service,aop,tx,dataSource,mybatis,mapper等)

web容器是root容器的子容器,父子容器關係。
父容器:root容器,盛放service、mapper、mybatis等相關組件
子容器:web容器,盛放controller、web相關組件

根據MVC三層架構配置三個配置類:

配置名 對應內容 對應容器
SpringMvcConfig controller,springmvc相關 web容器
SpringConfig service,aop,tx相關 root容器
MapperConfig mapper,datasource,mybatis相關 root容器

配置演示

控制層配置(SpringMVC)

主要配置Web工程的controller層配置

@Configurable
@ComponentScan(basePackages = {"com.evan.controller","com.evan.exceptionhandler"})
@EnableWebMvc
public class SpringMvcConfig implements WebMvcConfigurer {

    //開啟靜態資源訪問
    @Override
    public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
        configurer.enable();
    }

    //視圖解析器
    @Override
    public void configureViewResolvers(ViewResolverRegistry registry) {
        registry.jsp("/WEB-INF/views","jsp");
    }

    //配置視圖控制器
    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        registry.addViewController("/")
                .setStatusCode(HttpStatusCode.valueOf(200))
                .setViewName("index");
    }
}

業務層組件配置(Spring)

主要配置service,註解aop和聲明事務相關配置

@Configurable
@ComponentScan(basePackages = {"com.evan.service"})
@EnableAspectJAutoProxy
@EnableTransactionManagement
public class SpringConfig {

    //配置事務管理器
    @Bean
    public TransactionManager transactionManager(DataSource dataSource) {
        DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
        transactionManager.setDataSource(dataSource);
        return transactionManager;
    }

}

持久層配置(MyBatis)

主要配置mapper代理對象,連接池和mybatis核心組件配置

外部資料庫連接配置文件

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.username=root
jdbc.password=******
jdbc.url=jdbc://mysql://localhost:3306/dbtest1?serverTimezone=GMT%2B8&characterEncoding=utf-8
配置方式1(保留mybatis-config.xml)

依然保留mybatis的外部配置文件(xml), 但是資料庫連接信息交給Druid連接池配置!
缺點:依然需要mybatis-config.xml文件,進行xml文件解析,效率偏低!
mybatis-config.xml

資料庫信息以及mapper掃描包設置使用Java配置類處理!
mybatis其他的功能(別名、settings、插件等信息)依然在mybatis-config.xml配置!

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <settings>
        <!-- 開啟駝峰式映射-->
        <setting name="mapUnderscoreToCamelCase" value="true"/>
        <!-- 開啟logback日誌輸出-->
        <setting name="logImpl" value="SLF4J"/>
        <!--開啟resultMap自動映射 -->
        <setting name="autoMappingBehavior" value="FULL"/>
    </settings>

    <typeAliases>
        <!-- 給實體類起別名 -->
        <package name="com.evan.bean"/>
    </typeAliases>

    <plugins>
        <plugin interceptor="com.github.pagehelper.PageInterceptor">
            <!--
                helperDialect:分頁插件會自動檢測當前的資料庫鏈接,自動選擇合適的分頁方式。
                你可以配置helperDialect屬性來指定分頁插件使用哪種方言。配置時,可以使用下麵的縮寫值:
                oracle,mysql,mariadb,sqlite,hsqldb,postgresql,db2,sqlserver,informix,h2,sqlserver2012,derby
                (完整內容看 PageAutoDialect) 特別註意:使用 SqlServer2012 資料庫時,
                https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md#%E5%A6%82%E4%BD%95%E9%85%8D%E7%BD%AE%E6%95%B0%E6%8D%AE%E5%BA%93%E6%96%B9%E8%A8%80
             -->
            <property name="helperDialect" value="mysql"/>
        </plugin>
    </plugins>
</configuration>

持久層配置類

/**
 * @Author: lisong
 * @CreateTime: 2024-03-03 18:41 星期日
 * @Description:
 */
@Configurable
public class MyBatisConfig {

    //配置用於創建SqlSessionFactory的工廠bean
    @Bean
    public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource) {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        // 設置數據源
        sqlSessionFactoryBean.setDataSource(dataSource);
        // 設置MyBatis配置文件的路徑
        Resource resource = new ClassPathResource("mybatis-config.xml");
        sqlSessionFactoryBean.setMapperLocations(resource);
        //設置實體類對象別名
        sqlSessionFactoryBean.setTypeAliasesPackage("com.evan.bean");
        return sqlSessionFactoryBean;
    }

    /**
     * 配置mapper介面的掃描配置
     * 由mybatis-spring提供,可以將指定包下所有的mapper介面創建動態代理
     * 並將這些動態代理作為IOC容器的bean管理
     * @return
     */
    @Bean
    public MapperScannerConfigurer mapperScannerConfigurer() {
        MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
        //設置mapper介面和xml文件所在的共同包
        mapperScannerConfigurer.setBasePackage("com.evan.mapper");
        return mapperScannerConfigurer;
    }
}

說明:
在Spring配置類中添加了sqlSessionFactoryBeanmapperScannerConfigurerdatasource配置方法時,可能會導致@Value註解讀取不到值為null的問題。
這是因為SqlSessionFactoryBeanMapperScannerConfigurer是基於MyBatis框架的配置,它們的初始化順序可能會導致屬性註入的問題。
SqlSessionFactoryBeanMapperScannerConfigurer在配置類中通常是用來配置MyBatis相關的Bean,例如數據源、事務管理器、Mapper掃描等。這些配置類通常在@Configuration註解下定義,並且使用@Value註解來註入屬性值。
當配置類被載入時,Spring容器會首先處理Bean的定義和初始化,其中包括sqlSessionFactoryBeanmapperScannerConfigurer的初始化。在這個過程中,如果@Value註解所在的Bean還沒有被完全初始化,可能會導致註入的屬性值為null。
解決方案:
分成兩個配置類獨立配置,互不影響,資料庫提取一個配置類,mybatis提取一個配置類即可解決!

資料庫配置類

@Configurable
@PropertySource("classpath:jdbc.properties")
public class DataSourceConfig {

    @Value("${jdbc.url}")
    private String url;
    @Value("${jdbc.driver}")
    private String driver;
    @Value("${jdbc.username}")
    private String username;
    @Value("${jdbc.password}")
    private String password;

    //配置數據源
    @Bean
    public DataSource dataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(driver);
        dataSource.setUrl(url);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        return dataSource;
    }
}
配置方式2(完全配置類,去掉mybatis-config.xml)

不在保留mybatis的外部配置文件(xml), 所有配置信息(settings、插件、別名等)全部在聲明SqlSessionFactoryBean的代碼中指定!資料庫信息依然使用DruidDataSource實例替代!
優勢:全部配置類,避免了XML文件解析效率低問題!
mapper配置類

@Configurable
public class MapperConfig {

    //配置用於創建SqlSessionFactory的工廠bean
    @Bean
    public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource) {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        sqlSessionFactoryBean.setDataSource(dataSource);
        //Resource resource = new ClassPathResource("mybatis-config.xml");
        //sqlSessionFactoryBean.setMapperLocations(resource);

        //全局配置項,不要導錯包
        //org.apache.ibatis.session.Configuration
        Configuration configuration = new Configuration();
        //開啟駝峰式映射
        configuration.setMapUnderscoreToCamelCase(true);
        //開啟logback日誌輸出
        configuration.setLogImpl(Slf4jImpl.class);
        //開啟resultMap自動映射
        configuration.setAutoMappingBehavior(AutoMappingBehavior.FULL);
        sqlSessionFactoryBean.setConfiguration(configuration);

        //實體類對象別名設置
        sqlSessionFactoryBean.setTypeAliasesPackage("com.evan.bean");

        //分頁插件配置
        PageInterceptor pageInterceptor = getPageInterceptor();
        sqlSessionFactoryBean.addPlugins(pageInterceptor);
        return sqlSessionFactoryBean;
    }

    //分頁插件配置信息
    private static PageInterceptor getPageInterceptor() {
        PageInterceptor pageInterceptor = new PageInterceptor();
        Properties properties = new Properties();
        /*
        helperDialect:分頁插件會自動檢測當前的資料庫鏈接,自動選擇合適的分頁方式。
        你可以配置helperDialect屬性來指定分頁插件使用哪種方言。配置時,可以使用下麵的縮寫值:
        oracle,mysql,mariadb,sqlite,hsqldb,postgresql,db2,sqlserver,informix,h2,sqlserver2012,derby
        (完整內容看 PageAutoDialect) 特別註意:使用 SqlServer2012 資料庫時,
        https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md#%E5%A6%82%E4%BD%95%E9%85%8D%E7%BD%AE%E6%95%B0%E6%8D%AE%E5%BA%93%E6%96%B9%E8%A8%80
        */
        properties.setProperty("helperDialect","mysql");
        pageInterceptor.setProperties(properties);
        return pageInterceptor;
    }

    //配置Mapper實例掃描工廠,配置掃描package需要介面和mapper.xml文件同一個包
    @Bean
    public MapperScannerConfigurer mapperScannerConfigurer() {
        MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
        //設置mapper介面和xml文件所在的共同包
        mapperScannerConfigurer.setBasePackage("com.evan.mapper");
        return mapperScannerConfigurer;
    }
}

配置web項目初始化類

public class WebInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {

    //指定root IoC容器的配置類
    @Override
    protected Class<?>[] getRootConfigClasses() {
        return new Class[]{SpringConfig.class, MyBatisConfig.class, DataSourceConfig.class};
    }

    //指定web IoC容器的配置類
    @Override
    protected Class<?>[] getServletConfigClasses() {
        return new Class[]{SpringMvcConfig.class};
    }

    //DispatcherServlet請求分發的匹配路徑
    @Override
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
}

圖解配置類和容器配置:
image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 一、什麼是雙向綁定 我們先從單向綁定切入單向綁定非常簡單,就是把Model綁定到View,當我們用JavaScript代碼更新Model時,View就會自動更新雙向綁定就很容易聯想到了,在單向綁定的基礎上,用戶更新了View,Model的 ...
  • 前言 上周五晚上8點,開開心心的等著產品驗收完畢後就可以順利上線。結果產品突然找到我說要加需求,並且維護這一塊業務的同事已經下班走了,所以只有我來做。雖然內心一萬頭草泥馬在狂奔,但是嘴裡還是一口答應沒問題。由於這一塊業務很複雜並且我也不熟悉,加上還餓著肚子,在梳理代碼邏輯的時候我差點崩潰了。需要修改 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 一、組件是什麼 回顧以前對組件的定義: 組件就是把圖形、非圖形的各種邏輯均抽象為一個統一的概念(組件)來實現開發的模式,在Vue中每一個.vue文件都可以視為一個組件 組件的優勢 降低整個系統的耦合度,在保持介面不變的情況下,我們可以替換 ...
  • DataGear專業版 1.0.0 已發佈,歡迎試用! http://datagear.tech/pro/ DataGear 支持採用原生的HTML、JavaScript、CSS製作數據可視化看板,也支持導入由npm、vite等前端工具構建的前端程式包。得益於這一特性,可以很容易製作基於three. ...
  • 項目中用到了很多echart圖表,進行了簡單的組件封裝,主要包含以下功能: 創建圖表實例,渲染圖表 支持傳入自定義函數,可拿到圖表實例,實現個性化功能 支持配置更新後圖表自動刷新,可配置是清空後再刷新 loading狀態控制 resize時圖表更新 支持餅圖預設高亮功能 實現 資源引入 echart ...
  • react-native工程打包成apk 1. 生成簽名密鑰 使用jdk自帶的keytool生成密鑰 以管理員身份運行如下命令 keytool -genkey -v -keystore my-test3-key.keystore -alias my-key-test3 -keyalg RSA -ke ...
  • 使用XML文件配置SSM整合。 缺點:xml解析低,降低項目響應效率。 配置web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="ht ...
  • 訂單履約系統的概念模型 訂單:客戶提交購物請求後,生成的買賣合同,通常包含客戶信息、下單日期、所購買的商品或服務明細、價格、數量、收貨地址以及支付方式等詳細信息。 子訂單:為了更高效地進行履約,大訂單可能會被拆分成多個子訂單,子訂單會根據商品類型、配送地址、倉庫位置或供應商等因素進行拆分。 發貨單: ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...