天天看點

SSM整合

整合Spring

建立空白工程

SSM整合

導入springmvc依賴

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>5.2.7.RELEASE</version>
</dependency>
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>4.0.1</version>
</dependency>
           

applicationContext.xml

<context:component-scan base-package="com.qwl.metting"
                        use-default-filters="true">
    <context:exclude-filter type="annotation"
                            expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
           

use-default-filters屬性的預設值為 true,即使用預設的 Filter 進行包掃描,而預設的 Filter 對标有 @Service,@Controller和@Repository 的注解的類進行掃描,因為前面說過,

我們希望 SpringMVC隻來控制網站的跳轉邏輯,是以我們隻希望 SpringMVC 的配置掃描 @Controllerce注解标注的類,不希望它掃描其餘注解标注的類,是以設定了 use-default-filters 為 false,并使用 context:include-filter子标簽設定其隻掃描帶有 @Controller 注解标注的類。

而 Spring 就不同了,我們希望Spring 隻不掃描帶有 @Controller 注解标注的類,而掃描其他注解标注的類,而這時建立在使用預設的 Filter 進行掃描的基礎上,設定了context:exclude-filter 标簽,不掃描 @Controller注解标注的類.

spring-web.xml

<context:component-scan base-package="com.qwl"
                        use-default-filters="false">
    <context:include-filter type="annotation"
                            expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!-- 1.開啟SpringMVC注解模式 -->
<!-- 簡化配置: (1)自動注冊DefaultAnootationHandlerMapping,AnotationMethodHandlerAdapter 
        (2)提供一些列:資料綁定,數字和日期的format @NumberFormat, @DateTimeFormat, xml,json預設讀寫支援 -->
<mvc:annotation-driven/>

<!-- 2.靜态資源預設servlet配置 (1)加入對靜态資源的處理:js,gif,png (2)允許使用"/"做整體映射 -->
<mvc:resources mapping="/resources/**" location="/resources/" />
<mvc:default-servlet-handler />

<!-- 3.定義視圖解析器 -->
<bean id="viewResolver"
      class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/html/"></property>
    <property name="suffix" value=".html"></property>
</bean>
           

web.xml

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
</context-param>
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:spring-servlet.xml</param-value>
    </init-param>
</servlet>
<servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>

<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>forceRequestEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
    <init-param>
        <param-name>forceResponseEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
           

整合MyBatis

依賴

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>5.2.7.RELEASE</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.22</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.20</version>
</dependency>
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.5</version>
</dependency>
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>2.0.5</version>
</dependency>
           

db.properties

db.username=root
db.password=root
db.url=jdbc:mysql:///metting?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
           

添加

<!--引入資料庫的配置檔案-->
<context:property-placeholder location="classpath:db.properties"/>

<!--配置資料庫連接配接池-->
<bean class="com.alibaba.druid.pool.DruidDataSource" id="dataSource">
    <property name="username" value="${db.username}"/>
    <property name="password" value="${db.password}"/>
    <property name="url" value="${db.url}"/>
</bean>

<!--建立SqlSessionFactory對象-->
<bean class="org.mybatis.spring.SqlSessionFactoryBean" id="sqlSessionFactoryBean">
    <!--注入資料庫連接配接池-->
    <property name="dataSource" ref="dataSource"/>
    <!-- 配置MyBaties全局配置檔案:mybatis-config.xml -->
    <property name="configLocation" value="classpath:mybatis-config.xml" />
    <!-- 掃描entity包 使用别名 -->
    <property name="typeAliasesPackage" value="com.qwl.metting.entity"/>
    <!--mapperLocations:指定mapper檔案的位置-->
    <property name="mapperLocations" value="classpath*:com/qwl/metting/mapper/*.xml"/>
</bean>

<!-- 4.配置掃描mapper接口包,動态實作mapper接口,注入到spring容器中 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"
      id="mapperScannerConfigurer">
    <!-- 注入sqlSessionFactory -->
    <property name="sqlSessionFactoryBeanName" value="sqlSessionFactoryBean"/>
    <!-- 給出需要掃描mapper接口包 -->
    <property name="basePackage" value="com.qwl.metting.mapper"/>
</bean>
           

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>
		<!-- 使用jdbc的getGeneratedKeys擷取資料庫自增主鍵值 -->
		<setting name="useGeneratedKeys" value="true" />

		<!-- 使用列别名替換列名 預設:true -->
		<setting name="useColumnLabel" value="true" />

		<!-- 開啟駝峰命名轉換:Table{create_time} -> Entity{createTime} -->
		<setting name="mapUnderscoreToCamelCase" value="true" />
	</settings>
</configuration>
           

添加事務

添加依賴

<!--事務-->
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjrt</artifactId>
    <version>1.9.5</version>
</dependency>
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.9.5</version>
</dependency>
           

spring-server.xml

<!--包路徑掃描-->
<context:component-scan base-package="com.qwl.server"></context:component-scan>

<!-- 配置事務管理器 -->
<bean class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
      id="transactionManager">
    <!-- 注入資料庫連接配接池 -->
    <property name="dataSource" ref="dataSource"/>
</bean>

<!-- 1.配置基于注解的聲明式事務 -->
<tx:annotation-driven transaction-manager="transactionManager" />

<!--2-->
<!--事務的通知-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
    <tx:attributes>
        <tx:method name="add*"/>
        <tx:method name="insert*"/>
        <tx:method name="update*"/>
        <tx:method name="delete*"/>
    </tx:attributes>
</tx:advice>
 <!--切面的配置-->
<aop:config>
    <aop:pointcut id="pc1" expression="execution(* com.qwl.metting..service.*.*(..))"/>
    <aop:advisor advice-ref="txAdvice" pointcut-ref="pc1"/>
</aop:config>
           
ssm

繼續閱讀