SSM整合
文章目录
前言
一文解决Spring+SpringMVC+MyBatis整合配置
一、SpringMVC配置
SpringMVC处理请求和执行业务逻辑层,获取数据返回给视图层渲染
- 注解扫描(只需要扫描Controller 只需要处理请求即可)
- 视图解析器 InteralResourceViewResolver/RedirctViewResolver/ThymeleafViewResolver
主要配置视图前缀和视图后缀(主要配置ThymeleafViewResolver 这个配置较多) - 默认servlert 处理静态资源
- 开启springMVC注解驱动
- 文件上传解析器 multipartResolver
- 拦截器和异常处理器
1.1 xml配置
<?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:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:mv="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--注解扫描-->
<context:component-scan base-package="com.worker.ssm.controller"></context:component-scan>
<!--视图解析器-->
<!--将逻辑视图名称解析为Thymeleaf模板视图-->
<bean class="org.thymeleaf.spring5.view.ThymeleafViewResolver">
<property name="order" value="1"/>
<property name="characterEncoding" value="UTF-8"/>
<property name="templateEngine">
<!--处理模板并渲染结果-->
<bean class="org.thymeleaf.spring5.SpringTemplateEngine">
<!--加载Thymeleaf模板-->
<property name="templateResolver">
<bean class="org.thymeleaf.spring5.templateresolver.SpringResourceTemplateResolver">
<!--视图前缀-->
<property name="prefix" value="/WEB-INF/templates/"/>
<!--视图后缀-->
<property name="suffix" value=".html"/>
<!--模板解析的模式-->
<property name="templateMode" value="HTML5"/>
<property name="characterEncoding" value="UTF-8"/>
</bean>
</property>
</bean>
</property>
</bean>
<!--配置默认的servlet处理静态资源-->
<!--全部请求交给默认servlet处理-->
<mvc:default-servlet-handler/>
<!--开启mvc注解驱动-->
<mvc:annotation-driven/>
<!--配置视图解析器-->
<!--只配置这个 没有注解驱动开始 其余controller的都会失效
只会解析当前的视图控制器-->
<mvc:view-controller path="/" view-name="index"></mvc:view-controller>
<mv:view-controller path="/toAdd" view-name="employee_insert"></mv:view-controller>
<!--配置文件上传解析器 必须通过文件解析器的解析才能将文件转换为MultipartFile对象-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/>
<!--拦截器-->
<!--<mvc:interceptors>
<!–只配置bean | ref 默认是所有请求都拦截 效果一样–>
<bean></bean>
<ref></ref>
<!–配置具体拦截器的拦截规则–>
<mvc:interceptor>
<!–path写具体需要拦截的请求–>
<mvc:mapping path=""/>
<mvc:exclude-mapping path="/" />
<bean></bean>
</mvc:interceptor>
</mvc:interceptors>-->
<!--异常解析器-->
<!--<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<!–
properties的键表示处理器方法执行过程中出现的异常
properties的值表示若出现指定异常时,设置一个新的视图名称,跳转到指定页面
–>
<prop key="java.lang.ArithmeticException">error</prop>
</props>
</property>
<!–
exceptionAttribute属性设置一个属性名,将出现的异常信息在请求域中进行共享
–>
<property name="exceptionAttribute" value="ex"/>
</bean>-->
</beans>
1.2 注解配置
@Configuration
//扫描组件
@ComponentScan("com.atguigu.mvc.controller")
//开启MVC注解驱动
@EnableWebMvc
public class WebConfig implements WebMvcConfigurer {
//使用默认的servlet处理静态资源
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
//配置文件上传解析器
@Bean
public CommonsMultipartResolver multipartResolver(){
return new CommonsMultipartResolver();
}
//配置拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
FirstInterceptor firstInterceptor = new FirstInterceptor();
registry.addInterceptor(firstInterceptor).addPathPatterns("/**");
}
//配置视图控制
/*@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/").setViewName("index");
}*/
//配置异常映射
/*@Override
public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {
SimpleMappingExceptionResolver exceptionResolver = new SimpleMappingExceptionResolver();
Properties prop = new Properties();
prop.setProperty("java.lang.ArithmeticException", "error");
//设置异常映射
exceptionResolver.setExceptionMappings(prop);
//设置共享异常信息的键
exceptionResolver.setExceptionAttribute("ex");
resolvers.add(exceptionResolver);
}*/
//配置生成模板解析器
@Bean
public ITemplateResolver templateResolver() {
WebApplicationContext webApplicationContext = ContextLoader.getCurrentWebApplicationContext();
// ServletContextTemplateResolver需要一个ServletContext作为构造参数,可通过WebApplicationContext 的方法获得
ServletContextTemplateResolver templateResolver = new ServletContextTemplateResolver(
webApplicationContext.getServletContext());
templateResolver.setPrefix("/WEB-INF/templates/");
templateResolver.setSuffix(".html");
templateResolver.setCharacterEncoding("UTF-8");
templateResolver.setTemplateMode(TemplateMode.HTML);
return templateResolver;
}
//生成模板引擎并为模板引擎注入模板解析器
@Bean
public SpringTemplateEngine templateEngine(ITemplateResolver templateResolver) {
SpringTemplateEngine templateEngine = new SpringTemplateEngine();
templateEngine.setTemplateResolver(templateResolver);
return templateEngine;
}
//生成视图解析器并未解析器注入模板引擎
@Bean
public ViewResolver viewResolver(SpringTemplateEngine templateEngine) {
ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
viewResolver.setCharacterEncoding("UTF-8");
viewResolver.setTemplateEngine(templateEngine);
return viewResolver;
}
}
二、MyBatis配置
- 引入jdbc.properties
- 全局配置 settings
驼峰映射 lazyLoadingEnabled 开启延迟加载 aggressiveLazyLoading 开启按需加载 - 实体类类型别名 typeAliases
- 配置pageHelper 分页插件
- 配置连接数据库的环境 environments
配置事务管理器 数据源(连接数据库的四个基本配置) - 映射mapper文件 mappers
整合后可以将配置都交给spring管理
2.1 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>
<!-- 引入jdbc.properties-->
<settings>
<!--将下划线映射为驼峰-->
<setting name="mapUnderscoreToCamelCase" value="true"/>
<!--开启延迟加载-->
<setting name="lazyLoadingEnabled" value="true"/>
<!--按需加载-->
<setting name="aggressiveLazyLoading" value="false"/>
</settings>
<!-- 设置类型别名对应的包 -->
<!-- 设置插件 -->
<!--设置分页插件-->
<!-- 设置数据源和事务管理器 -->
<!--引入映射文件-->
</configuration>
2.2 注解配置
@Configuration
/* 扫描组件 配置自定义扫描规则 */
@ComponentScan(basePackages = "com.worker",useDefaultFilters = false,excludeFilters = {
@ComponentScan.Filter(type = FilterType.ANNOTATION,classes = {Controller.class})
})
@PropertySource({"classpath:jdbc.properties"})//从哪个properties文件中取值
@EnableTransactionManagement //事务注解解析器
public class SpringConfig {
@Value("${prop.jdbcDriveClass}")//value注解代表把文件中的值赋值给此变量
private String driver;
@Value("${prop.url}")
private String url;
@Value("${prop.username}")
private String user;
@Value("${prop.password}")
private String password;
@Bean(name = "dataSource")//给方法取名字
public DataSource getDataSource() {
DriverManagerDataSource driverManagerDataSource = new DriverManagerDataSource();
driverManagerDataSource.setDriverClassName(driver);
driverManagerDataSource.setUrl(url);
driverManagerDataSource.setUsername(user);
driverManagerDataSource.setPassword(password);
return driverManagerDataSource;
}
@Bean(name = "jdbcTemplate")
public JdbcTemplate createJdbcTemplate(DataSource dataSource) {
return new JdbcTemplate(dataSource);
}
//创建事务管理的Bean
@Bean
public DataSourceTransactionManager createTransactionManager(DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
// 整合MyBatis
@Bean
public SqlSessionFactoryBean getSqlSessionFactoryBean(@Autowired DataSource dataSource){
SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
/* 数据源 */
sqlSessionFactoryBean.setDataSource(dataSource);
/* 类型别名所对应的包 */
sqlSessionFactoryBean.setTypeAliasesPackage("com.worker.pojo");
return sqlSessionFactoryBean;
}
// 配置mapper接口扫描 将mapper接口的代理实现类交给springIOC管理
// 你可以使用一个MapperScannerConfigurer,它将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean
@Bean
public MapperScannerConfigurer getMapperScannerConfigurer(){
MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
mapperScannerConfigurer.setBasePackage("com.worker.mapper");
return mapperScannerConfigurer;
}
}
三、Spring整合配置
- 扫描组件(除控制层)
- 配置数据源
- 配置事务管理器
- 开启事务注解驱动
- 整合mybatis
SqlSessionFactoryBean==》配置mybatis的核心配置
也可以引入mybatis的核心配置文件 区分mybatis的配置
配置mapper接口扫描
3.1 xml配置
<?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:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/tx https://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- =========== 扫描组件(除控制层) ============ -->
<context:component-scan base-package="com.worker.ssm">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!-- ============= 配置数据源 ====================== -->
<!-- 引入jdbc.properties -->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!-- 配置Druid数据源 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${prop.driver}"/>
<property name="url" value="${prop.url}"/>
<property name="username" value="${prop.username}"/>
<property name="password" value="${prop.password}"/>
</bean>
<!-- ================= 配置事务管理器 ==================== -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!--
开启事务的注解驱动
将使用@Transactional标识的方法和类中所有的方法进行事务管理
-->
<tx:annotation-driven transaction-manager="transactionManager" />
<!-- ============== 整合mybatis =============== -->
<bean class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 设置mybatis核心配置文件的路径 -->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<!-- 设置mybatis配置 -->
<!--设置数据源-->
<property name="dataSource" ref="dataSource"/>
<!-- 设置类型别名所对应的包 -->
<property name="typeAliasesPackage" value="com.worker.ssm.pojo"/>
<!-- 设置全局配置 -->
<!--<property name="configurationProperties">
<props>
<prop key=""></prop>
</props>
</property>-->
<!-- 设置mapper映射文件 只有映射文件的包不一致才需要配置 -->
<!--<property name="mapperLocations" value="classpath:mapper/*.xml"/>-->
<!-- 配置插件 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor"></bean>
</array>
</property>
</bean>
<!-- 配置mapper接口扫描 -->
<!--
指定包下的mapper接口 通过SqlSession创建代理实现类对象
并将这些对象交给IOC容器管理 就可以自动装配mapper
-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.worker.ssm.mapper"/>
</bean>
</beans>
3.2 注解配置
@Configuration
public class SpringConfig {
//ssm整合之后,spring的配置信息写在此类中
}
四、web.xml
- 配置编码/处理请求的过滤器
- 设置前端控制器DispatcherServlet
- 配置spring的监听器(在服务器启动时加载spring的配置文件 可以在SpringMVC处理请求前为Controller注入service)
- 配置spring配置文件自定义的位置和名称
4.1 web.xml
<?xml version="1.0" encoding="UTF-8" ?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--配置编码过滤器-->
<filter>
<filter-name>CharacterEncodingFilter</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>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!--配置处理请求方式的过滤器-->
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!--配置前端控制器-->
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--配置SpringMVC配置文件自定义的位置和名称-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!--将DispatherServlet的初始化时间提前到服务器启动时-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--配置spring的监听器 在服务器启动时加载spring的配置文件-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!--配置spring配置文件自定义的位置和名称-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring.xml</param-value>
</context-param>
</web-app>
4.2 注解配置
public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {
/**
* 指定spring的配置类
* @return
*/
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[]{SpringConfig.class};
}
/**
* 指定SpringMVC的配置类
* @return
*/
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{WebConfig.class};
}
/**
* 指定DispatcherServlet的映射规则,即url-pattern
* @return
*/
@Override
protected String[] getServletMappings() {
return new String[]{"/"};
}
/**
* 添加过滤器
* @return
*/
@Override
protected Filter[] getServletFilters() {
CharacterEncodingFilter encodingFilter = new CharacterEncodingFilter();
encodingFilter.setEncoding("UTF-8");
encodingFilter.setForceRequestEncoding(true);
HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();
return new Filter[]{encodingFilter, hiddenHttpMethodFilter};
}
}
五、扩展配置
5.1 log4j.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<param name="Encoding" value="UTF-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n"/>
</layout>
</appender>
<logger name="java.sql">
<level value="debug"/>
</logger>
<logger name="org.apache.ibatis">
<level value="info"/>
</logger>
<root>
<level value="debug"/>
<appender-ref ref="STDOUT"/>
</root>
</log4j:configuration>
5.2 log4j2.xml
<?xml version="1.0" encoding="UTF-8"?>
<?xml version="1.0" encoding="UTF-8"?>
<!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE >
ALL -->
<!--Configuration 后面的 status 用于设置 log4j2 自身内部的信息输出,可以不设置,
当设置成 trace 时,可以看到 log4j2 内部各种详细输出-->
<configuration status="INFO">
<!--先定义所有的 appender-->
<appenders>
<!--输出日志信息到控制台-->
<console name="Console" target="SYSTEM_OUT">
<!--控制日志输出的格式-->
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-
5level %logger{36} - %msg%n"/>
</console>
</appenders>
<!--然后定义 logger,只有定义 logger 并引入的 appender,appender 才会生效-->
<!--root:用于指定项目的根日志,如果没有单独指定 Logger,则会使用 root 作为
默认的日志输出-->
<loggers>
<root level="info">
<appender-ref ref="Console"/>
</root>
</loggers>
</configuration>
总结
这里写的肯定也只是整合配置的主要使用的实例,希望对你们有所帮助