发表于: 2017-10-31 22:35:44
1 777
一.今日完成
使用SSM框架做了多个项目,对不少一知半解,参考网络资源以及经验总结,梳理了SSM框架整合配置
1.web.xml的配置
servlet3.0以前每个servlet必须要在web.xml中配置servlet及其映射关系;但是servlet3.0开始支持注解配置方式。需要在web.xml配置前端控制器(DispatcherServlet),方式与普通的servlet基本相似。
<!-- 配置前端控制器 -->
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<!-- ContextconfigLocation配置springmvc加载的配置文件
适配器、处理映射器等
-->
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applcationContext-*.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>spring</servlet-name>
<!-- 1、.action访问以.action结尾的 由DispatcherServlet进行解析
2、/,所有访问都由DispatcherServlet进行解析
-->
<url-pattern>/</url-pattern>
</servlet-mapping>
在<servlet-mapping>中url如果是.action,前端控制器就只会拦截以.action结尾的请求,并不会理会静态的文件。对静态页面的控制就要通过其他的手段。以/作为url的话就会拦截所有的请求,包括静态页面的请求。这样的话就可以拦截任何想要处理的请求,但是有一个问题。如果拦截了所有的请求,如果不在拦截器中做出相应的处理,那么所有静态的js、css以及页面中用到的图片就会访问不到造成页面无法正常显示。但这可以通过静态资源的配置来解决这个问题。
配置spring容器:
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>WEB-INF/classes/spring/applicationContext-*.xml</param-value>
</context-param>
其中applicationContext-*.xml包含3个配置文件,是springIoC容器的具体配置。
配置一个监听器:
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
配置编码过滤器:
<!-- 编码过滤器 -->
<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>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
2.springmvc.xml的配置
视图解析器的配置:
<!-- 配置视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 使用前缀和后缀 -->
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
自动扫描方式,扫描包下面所有的Controller,可以使用注解来指定访问路径:
<!-- 自动扫描 @Controller-->
<context:component-scan base-package="com.oab.quagga"/>
配置注解的处理器适配器和处理器映射器:
<!-- 注解的处理器适配器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
<!-- 注解的处理器映射器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
配置拦截器,可以直接定义拦截所有请求,也可以自定义拦截路径:
<mvc:interceptors>
<!-- 直接定义拦截所有请求 -->
<bean class="com.oabquagga.util.IdentityInterceptor"></bean>
<!-- <mvc:interceptor>
拦截所有路径的请求 包括子路径
<mvc:mapping path="/**"/>
<bean class="com.wxisme.ssm.interceptor.IdentityInterceptor"></bean>
</mvc:interceptor> -->
</mvc:interceptors>
配置全局异常处理器:
<!-- 定义全局异常处理器 -->
<!-- 只有一个全局异常处理器起作用 -->
<bean id="exceptionResolver" class="com.oab.quagga.util.OverallExceptionResolver"></bean>
配置文件上传数据解析器,在上传文件时需要配置:
<!--配置上传文件数据解析器 -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize">
<value>9242880</value>
</property>
如果在配置前端控制器时拦截了所有的请求,不做特殊处理就会导致部分静态资源无法使用。如果是这种情况就可以使用下面的配置来访问静态资源文件:
<mvc:resources mapping="/images/**" location="/images/" />
<mvc:resources mapping="/css/**" location="/css/" />
<mvc:resources mapping="/js/**" location="/js/" />
<mvc:resources mapping="/imgdata/**" location="/imgdata/" />
或者添加配置:
<!-- 访问静态资源文件 -->
<mvc:default-servlet-handler />
3.applicationContext-*.xml的配置
applicationContext-*.xml包括三个配置文件,分别对应数据层控制、业务逻辑service控制和事务的控制。
(1)数据访问层的控制,在applicationContext-dao.xml的配置:
配置加载数据连接资源文件的配置,把数据库连接数据抽取到一个properties资源文件中方便管理,db.propertise需要另外单独配置
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location" value="classpath:db.properties"/>
</bean>
配置连接池:
<!--配置数据源-->
<bean id="dataSourceHikari" class="com.zaxxer.hikari.HikariDataSource" destroy-method="shutdown">
<property name="driverClassName" value="${driverClasss}" />
<property name="jdbcUrl" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="readOnly" value="${readOnly}" />
<property name="connectionTimeout" value="${connectionTimeout}" />
<property name="idleTimeout" value="${idleTimeout}" />
<property name="maxLifetime" value="${maxLifetime}" />
<property name="maximumPoolSize" value="${maximumPoolSize}" />
<property name="minimumIdle" value="${minimumIdle}" />
</bean>
Spring和MyBatis整合配置,jar包由MyBatis提供。
1)配置sqlSessionFactory
<!-- 配置sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 数据库连接池 -->
<property name="dataSource" ref="dataSourceHikari"/>
<!-- 加载Mybatis全局配置文件 -->
<property name="configLocation" value="/resources/SqlMapConfig.xml"></property>
</bean>
2)配置Mapper扫描器,扫描mapper包下的所有mapper文件和类,要求mapper配置文件和类名需要一致
<!-- 配置mapper扫描器 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 扫描包路径,如果需要扫描多个包中间用半角逗号隔开 -->
<property name="basePackage" value="com.oab.quagga.dao"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
(2)业务逻辑控制,applicationContext-service.xml的配置:
需要定义service的实现类:
<!-- 定义service -->
<bean id="userService" class="com.oab.quagga.service.impl.UserServiceImpl"/>
(3)事务控制,applicationContext-transaction.xml的配置
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 配置数据源 -->
<property name="dataSource" ref="dataSourceHikari"/>
</bean>
配置通知,事务控制:
<!-- 通知 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 传播行为 -->
<tx:method name="save*" propagation="REQUIRED"/>
<tx:method name="insert*" propagation="REQUIRED"/>
<tx:method name="update*" propagation="REQUIRED"/>
<tx:method name="delete*" propagation="REQUIRED"/>
<tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
<tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
</tx:attributes>
</tx:advice>
3.MyBatis的配置
(1)SqlMapConfig.xml的配置
别名的定义:
<typeAliases>
<!-- 批量定义别名 ,指定包名,自动扫描包中的类,别名即为类名,首字母大小写无所谓-->
<package name="com.oab.quagga.domain"/>
</typeAliases>
mapper映射文件的配置:
<mappers>
<!-- 加载映射文件 -->
<!-- 这里也可以使用class来加载映射文件,前提是:使用mapper代理的方法,遵循规范,
并且两个文件必须同名且在同一目录
<mapper class="com.oab.quagga.dao.UserDao"/>
基于class加载,可以进行批量加载
-->
<!-- 通过扫描包的方式来进行批量加载映射文件 -->
<package name="com.oab.quagga.dao"/>
</mappers>
4.在使用mapper代理的方法时,命名空间需要是对应的Mapper类。
对SSM框架简单使用时的配置文件如上,使用其他功能需要参考官方文档.
配置文件结构:
二.明日计划
根据以上框架结构修改任务7的代码
三.遇到问题
暂无.
四.收获
以上.
评论