SSM框架整合
SSM框架,是目前比較主流的一個組合開發框架,SSM指的是Spring,SpringMVC,Mybatis。這三個框架,分別爲SSM提供着面向切面,控制反轉,依賴注入,前端控制器,持久層開發等功能。
Spring導包
Spring讓人聽得的最多的就是面向切面(AOP)和控制反轉(IOC)。
控制反轉:主要是指new對象方面,把new的責任交給了Spring,不用我們程序員自己去操作。這方面涉及到了代理模式,點擊查看我對代理的理解
面向切面:是指對程序的過程進行權限攔截,運行監控等聲明式事物的支持。
對於Spring的依賴,我是通過Maven進行導包。 目前在對Spring的依賴導包上,所有人都導:
- Spring-context (必要)
- Spring-expression(必要)
- Spring-aop (必要)
- Spring-beans (必要)
- Spring-core (必要)
- Spring-web(必要)
- Spring-tx (事務聲明,非必要)
- Spring-jdbc (功能必要)
但是其實,對於Spring的包,如果你只用到IOC的話,你只需要導:
<!-- 僅僅使用IOC導這個就夠了 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
到時候1-5都會被導進去,剩下的看項目所需自己在Maven官網搜索導入pom.xml裏就行了
SpringMVC導包
SpringMVC 的包比較簡單,它只需要導Spring-mvcweb就行,運用到的主要還是前端控制器管理所有頁面發過來的URL。
但是要注意的一點是:來自同一個系列包的版本必須一致
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
Mybatis導包
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.2.6</version>
</dependency>
在SSM裏面,Mybatis除了到自己的包以外,還需要導:
- 數據庫包與連接池包
<!-- 導入Mysql數據庫鏈接jar包 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.36</version>
</dependency>
<!-- 導入c3p0的jar包,用來在applicationContext.xml中配置數據庫 -->
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
version>0.9.5.2</version>
</dependency>
- Mybatis與Spring的連接包
<!-- mybatis/spring包 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.2.2</version>
</dependency>
日誌方面建議導個log4j:
<!-- 日誌文件管理包 -->
<!-- log start -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
配置文件目錄結構:
1、appliaction-dao,-service-trans。這三個文件可以整合成一個,爲了方便大家理解,我將它們區分開來了。
2、下面的xml裏面,com.XXXX 這是個人目錄名字,爲了初學者好理解,我換成XXXX。
applicationContext-dao.xml
<!-- 配置 讀取properties文件 jdbc.properties -->
<context:property-placeholder location="classpath:jdbc.properties" />
<!-- 配置 c3p0數據源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driver}" />
<property name="jdbcUrl" value="${jdbc.url}" />
<property name="user" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
<!-- 配置SqlSessionFactory -->
<bean class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 設置MyBatis核心配置文件 -->
<property name="configLocation" value="classpath:SqlMapConfig.xml" />
<!-- 設置數據源 -->
<property name="dataSource" ref="dataSource" />
<!-- 別名包掃描 -->
<property name="typeAliasesPackage" value="com.XXXXX.pojo" />
<!-- 配置mapper路徑 -->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!-- 配置Mapper掃描 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 設置Mapper掃描包 -->
<property name="basePackage" value="com.XXXXX.mapper" />
</bean>
applicationContext-service.xml
<!-- 配置Service掃描 -->
<context:component-scan base-package="com.XXXXX.service" />
applicationContext-trans.xml
<!-- 事務管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 數據源 -->
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 通知 Spring-tx -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 傳播行爲 -->
<tx:method name="save*" propagation="REQUIRED" />
<tx:method name="insert*" propagation="REQUIRED" />
<tx:method name="add*" propagation="REQUIRED" />
<tx:method name="create*" propagation="REQUIRED" />
<tx:method name="delete*" propagation="REQUIRED" />
<tx:method name="update*" propagation="REQUIRED" />
<tx:method name="find*" propagation="SUPPORTS" read-only="true" />
<tx:method name="select*" propagation="SUPPORTS" read-only="true" />
<tx:method name="get*" propagation="SUPPORTS" read-only="true" />
<tx:method name="query*" propagation="SUPPORTS" read-only="true" />
</tx:attributes>
</tx:advice>
<!-- 切面 -->
<aop:config>
<aop:advisor advice-ref="txAdvice"
pointcut="execution(* com.XXXX.service.*.*(..))" />
</aop:config>
SpringMVC.xml
<!-- 配置Controller掃描 -->
<context:component-scan base-package="com.XXXXX.controller"/>
<!-- 配置註解驅動 -->
<mvc:annotation-driven conversion-service="MyConvert"/>
<!-- 定義日期轉化器 -->
<bean id="MyConvert" class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
<property name="converters">
<set>
<bean class="com.XXXXX.utils.DateConvert"/>
</set>
</property>
</bean>
<!-- 靜態資源 -->
<mvc:default-servlet-handler/>
<!-- 配置視圖解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 前綴 -->
<property name="prefix" value="/WEB-INF/html/" />
<!-- 後綴 -->
<property name="suffix" value=".jsp" />
</bean>
jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/XXXX?characterEncoding=utf-8
jdbc.username=root
jdbc.password=root
log4j.properties
# Global logging configuration
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
SqlMapConfig.xml
一般可以不用配置
最後、便是web.xml的配置了
web.xml的作用是把這些配置文件連接起來
<!-- 配置spring -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext-*.xml</param-value>
</context-param>
<!-- 配置SpringMVC -->
<servlet>
<servlet-name>boot-zj</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springmvc.xml</param-value>
</init-param>
<!-- 配置springmvc什麼時候啓動,參數必須爲整數 -->
<!-- 如果爲0或者大於0,則springMVC隨着容器啓動而啓動 -->
<!-- 如果小於0,則在第一次請求進來的時候啓動 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>boot-zj</servlet-name>
<!-- 所有的請求都進入springMVC -->
<url-pattern>/</url-pattern>
</servlet-mapping>
對於web.xml的具體配置請點擊查看原文