目录
一、SSM框架整合。
(1)核心笔记。
(1.1)Spring、SpringMVC、MyBatis三者的配置。
(1.2)请求字符集格式与响应字符集格式。
(2)原始方式整合。
(2.1)controller层。
(2.2)service层。
(2.3)mapper层(dao层)。
(2.4)domain层实体类。
(2.5)web.xml文件。
(2.6)spring的相关配置。
(2.7)springMVC的相关配置。
(2.8)mybatis相关的配置。
(2.9)log4j.properties文件:
(2.10)原始整合方式的流程文档参考。
(3)Spring整合MyBatis。
一、SSM框架整合。
(1)核心笔记。
(1.1)Spring、SpringMVC、MyBatis三者的配置。
Spring:配置Listener(web.xml中)、applicationContext.xml配置文件。
SpringMVC:配置CharacterEncodingFilter(web.xml中)、spring-mvc.xml配置文件。
MyBatis:配置映射文件、核心文件、映射接口类(相当于dao类)。
注意:web.xml文件中:配置spring监听器、springmvc前端控制器。
(1.2)请求字符集格式与响应字符集格式。
请求字符集格式:
<!--3、乱码过滤器(这里的是请求的字符集过滤,不包含响应的(即响应可能中文出现乱码))-->
<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>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
响应字符集格式:
注意1:如果在类上的注解上写produces,则所有类都有这个属性,如果在方法上写,只有当前方法有。
注意2:produces = "text/html;charset=utf-8";这个是设置响应时的字符集编码。
@Controller
@RequestMapping( value = "/account",produces = "text/html;charset=utf-8")
public class AccountController {
@Autowired
private AccountService accountService;
//保存
/* 注意:如果在类上的注解上写produces,则所有类都有这个属性,如果在方法上写,只有当前方法有*/
/*注意:produces = "text/html;charset=utf-8";这个是设置响应时的字符集编码*/
@RequestMapping(value = "/save"/*,produces = "text/html;charset=utf-8"*/)
@ResponseBody
public String save(Account account) throws IOException {
accountService.save(account);
return "保存成功!";
}
//查询
@RequestMapping("/findAll")
public ModelAndView findAll() throws IOException {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("accountList");
modelAndView.addObject("accountList",accountService.findAll());
return modelAndView;
}
}
(2)原始方式整合。
(2.1)controller层。
package controller;
@Controller
@RequestMapping( value = "/account",produces = "text/html;charset=utf-8")
public class AccountController {
@Autowired
private AccountService accountService;
//保存
/* 注意:如果在类上的注解上写produces,则所有类都有这个属性,如果在方法上写,只有当前方法有*/
/*注意:produces = "text/html;charset=utf-8";这个是设置响应时的字符集编码*/
@RequestMapping(value = "/save"/*,produces = "text/html;charset=utf-8"*/)
@ResponseBody
public String save(Account account) throws IOException {
accountService.save(account);
return "保存成功!";
}
//查询
@RequestMapping("/findAll")
public ModelAndView findAll() throws IOException {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("accountList");
modelAndView.addObject("accountList",accountService.findAll());
return modelAndView;
}
}
(2.2)service层。
1.接口:
package server;
public interface AccountService {
public void save(Account account) throws IOException;
public List<Account> findAll() throws IOException;
}
2.接口实现类:
package server.impl;
@Service("accountService")
public class AccountServiceImpl implements AccountService {
@Override
public void save(Account account) throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
AccountMapper mapper = sqlSession.getMapper(AccountMapper.class);
mapper.save(account);
sqlSession.commit();
sqlSession.close();
}
@Override
public List<Account> findAll() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
AccountMapper mapper = sqlSession.getMapper(AccountMapper.class);
List<Account> accountList = mapper.findAll();
sqlSession.commit();
sqlSession.close();
return accountList;
}
}
(2.3)mapper层(dao层)。
接口(只需接口,不需要实现类):
package mapper;
public interface AccountMapper {
public void save(Account account);
public List<Account> findAll();
}
(2.4)domain层实体类。
package domain;
public class Account {
private Integer id;
private String name;
private Double money;
//省略setter与getter方法。
}
(2.5)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">
<!--1、Spring监听器-->
<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>
<!--2、springmvc前端控制器-->
<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-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern><!--缺省(默认)-->
</servlet-mapping>
<!--3、乱码过滤器(这里的是请求的字符集过滤,不包含响应的(即响应可能中文出现乱码))-->
<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>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
(2.6)spring的相关配置。
<?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"
xsi:schemaLocation="http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--1、组件扫描 扫描service和mapper-->
<context:component-scan base-package="com.itheima">
排除controller的扫描
而context:exclude-filter标签则配置了要排除扫描的组件类型为标注了"@Controller"注解的类。
expression属性用于指定要排除的组件类型或条件。对于type="annotation"为注解,expression属性通常会指定一个注解类型
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"></context:exclude-filter>
</context:component-scan>-->
<context:component-scan base-package="server"/>
<context:component-scan base-package="mapper"/>
</beans>
(2.7)springMVC的相关配置。
<?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"
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--1、组件扫描 主要扫描controller-->
<context:component-scan base-package="controller"/>
<!--2、配置mvc驱动-->
<mvc:annotation-driven/>
<!--3、内部资源解析器-->
<bean id="resourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"/>
<property name="suffix" value=".jsp"/>
</bean>
<!--4、开发静态资源的访问权限-->
<mvc:default-servlet-handler/>
</beans>
(2.8)mybatis相关的配置。
1.映射文件:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="mapper.AccountMapper">
<insert id="save" parameterType="domain.Account">
insert into account values(#{id},#{name},#{money})
</insert>
<select id="findAll" resultType="Account">
select * from account
</select>
</mapper>
2.properties文件:
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test
jdbc.username=root
jdbc.password=tan
3.核心配置文件:
<?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>
<!--1、加载properties文件-->
<properties resource="jdbc.properties"/>
<!--2、定义别名-->
<typeAliases>
<!--<typeAlias type="domain.Account" alias="account"></typeAlias>-->
<!--扫包,命名为:实体名称(Account) 或 包内的实体名称的首字母小写,如Account 》 account ;两种都可以-->
<package name="domain"/>
</typeAliases>
<!--3、配置数据源环境-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!--4、加载映射-->
<mappers>
<!--<mapper resource="mapper/AccountMapper.xml"/>-->
<!--不管是接口还是xml文件都可以用这个,但是如果接口不是使用注解配置的,那么使用
包扫描,这个包名(或几个同名的)下里面,必须有映射文件和接口,否则报错-->
<package name="mapper"/>
</mappers>
</configuration>
(2.9)log4j.properties文件:
#
# Hibernate, Relational Persistence for Idiomatic Java
#
# License: GNU Lesser General Public License (LGPL), version 2.1 or later.
# See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
#
### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.err
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### direct messages to file hibernate.log ###
#log4j.appender.file=org.apache.log4j.FileAppender
#log4j.appender.file.File=hibernate.log
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### set log levels - for more verbose logging change 'info' to 'debug' ###
log4j.rootLogger=all, stdout
(2.10)原始整合方式的流程文档参考。
(3)Spring整合MyBatis。
1.主要是修改service层的代码(只改了一个,方便对比):
package server.impl;
@Service("accountService")
public class AccountServiceImpl implements AccountService {
@Autowired
private AccountMapper accountMapper;
@Override
public void save(Account account) throws IOException {
accountMapper.save(account);
}
@Override
public List<Account> findAll() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
AccountMapper mapper = sqlSession.getMapper(AccountMapper.class);
List<Account> accountList = mapper.findAll();
sqlSession.commit();
sqlSession.close();
return accountList;
}
}
2.spring配置文件:
<?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"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--1、组件扫描 扫描service和mapper-->
<context:component-scan base-package="server"/>
<context:component-scan base-package="mapper2"/>
<!--2、加载properties文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--3、配置数据源-->
<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>
<!--4、配置SqlSessionFactory(是一个接口,使用实现类获取该类型)-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--注入数据源对象-->
<property name="dataSource" ref="dataSource"/>
<!--加载(注入)mubatis核心文件-->
<property name="configLocation" value="classpath:sqlMapConfig-spring.xml"/>
</bean>
<!--5、代替mybatis核心文件的mappers标签.(扫描之后会为接口生成实现类注册到IOC容器中)
1、如果接口不是使用注解配置的,那么使用包扫描,这个包名(或几个同名的)下里面,必须有映射文件和接口,否则报错
2、比如接口在mapper包下,映射文件在mapper2下,扫描mapper包报错,扫描mapper2包也报错(直接指定xml文件不报错)
3、如果把接口所在的mapper包改为mapper2,已经映射文件所在的mapper包改为mapper2,然后正常运行。
4、测试结果:扫描的包,接口以及映射文件都要在扫描的包内。(测试环境:不同包,但包名相同)-->
<!--
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 标签是用来配置 MyBatis 和 Spring 整合时
自动扫描 Mapper 接口并将其注册到 Spring IOC 容器的组件。 通过配置 <property name="basePackage" value="mapper2"/> 属性,
MyBatis 会扫描 mapper2 包及其子包中所有的 Mapper 接口,并自动为其生成代理对象。-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--扫描mapper2所在的包,为mapper2创建实现类-->
<property name="basePackage" value="mapper2"/>
</bean>
<!--6、声明式事务控制-->
<!--平台事务管理器-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!--配置事务增强-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*"/>
</tx:attributes>
</tx:advice>
<!--事务的AOP织入-->
<aop:config>
<aop:advisor advice-ref="txAdvice" pointcut="execution(* service.Impl.*.*(..))"></aop:advisor>
</aop:config>
</beans>
3.mybatis核心文件:
<?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>
<!--2、定义别名-->
<typeAliases>
<!--<typeAlias type="domain.Account" alias="account"></typeAlias>-->
<!--扫包,命名为:实体名称(Account) 或 包内的实体名称的首字母小写,如Account 》 account ;两种都可以-->
<package name="domain"/>
</typeAliases>
</configuration>