一. 简介:
SSM:分别由 Spring, SpringMvc ,MyBatis组成
二. 步骤
1.集成SpringMvc
2.集成Maybatis
1.集成SpringMvc
1.1 导入21个jar文件(包含spring的jar)
1.2。applicationContext-mvc.xml 的5大配置
mvc静态资源放行,
mvc注解支持,
Controller的扫描路径
视图解析器,
上传解析器
<!-- 开启springmvc对静态资源的处理 -->
<mvc:default-servlet-handler />
<!-- 开启springmvc的注解开关 -->
<context:annotation-config />
<context:component-scan base-package="cn.itsource.ssm.controller" />
<!-- 文件的上次和下载 -->
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize">
<value>200000000</value>
</property>
</bean>
<!-- 配置视图解析器:前缀和后缀的配置 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsps/" />
<property name="suffix" value=".jsp" />
</bean>
1.3 web.xml
1.post乱码过滤器
2.springmvc核心控制器
<!-- post提交中文乱码的过滤器 -->
<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>
<!-- 加载spring配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- spring的监听配置 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 启动的时候加载spring-mvc的配置文件 -->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
1.4 SpringMvc的测试
Controller跳转到jsp页面
@RequestMapping("/dept/index")
public String index(Model model){
return "dept/index";
}
2. 集成MyBatis
2.1 加入MyBatis相关9个 jar包(mybatis-spring-1.2.0.jar)
1.核心包
2.依赖包
3.数据库连接包
2.2 Spring和MyBatis的集成方式
1.Spring配置文件
1. 1 SSM注入顺序
<!-- jdbc.properties->dataSource->sqlSessionFactory->mapper(dao)->service->controller(action) -->
1.2 jdbc配置文件&数据源dataSource
<!-- 引入jdbc的配置 -->
<context:property-placeholder location="classpath:*properties"/>
<!-- 数据源dataSource -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<!-- 依赖注入连接池需要的属性 -->
<!-- property name="是BasicDataSource的set方法,本质属性" -->
<!-- property value="是jdbc.properties配置文件的key" -->
<property name="driverClassName" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<!--maxActive: 最大连接数量 -->
<property name="maxActive" value="150" />
<!--minIdle: 最小空闲连接 -->
<property name="minIdle" value="5" />
<!--maxIdle: 最大空闲连接 -->
<property name="maxIdle" value="20" />
<!--initialSize: 初始化连接 -->
<property name="initialSize" value="30" />
<!-- 连接被泄露时是否打印 -->
<property name="logAbandoned" value="true" />
<!--removeAbandoned: 是否自动回收超时连接 -->
<property name="removeAbandoned" value="true" />
<!--removeAbandonedTimeout: 超时时间(以秒数为单位) -->
<property name="removeAbandonedTimeout" value="10" />
<!--maxWait: 超时等待时间以毫秒为单位 1000等于60秒 -->
<property name="maxWait" value="1000" />
<!-- 在空闲连接回收器线程运行期间休眠的时间值,以毫秒为单位. -->
<property name="timeBetweenEvictionRunsMillis" value="10000" />
<!-- 在每次空闲连接回收器线程(如果有)运行时检查的连接数量 -->
<property name="numTestsPerEvictionRun" value="10" />
<!-- 1000 * 60 * 30 连接在池中保持空闲而不被空闲连接回收器线程 -->
<property name="minEvictableIdleTimeMillis" value="10000" />
<property name="validationQuery" value="SELECT NOW() FROM DUAL" />
</bean>
1.3 SqlSessionFactoryBean的配置:看官方集成文档和源码(引入数据源、别名、mapper、)
获取sqlSessionFactory方案
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!—引入数据源-- >
<property name="dataSource" ref="dataSource" />
<!—加载所有的mapper路径-- >
<property name="mapperLocations" value="classpath:cn/itsource/ssm/mapper/*Mapper.xml"/>
<!—配置别名 -- >
<property name="typeAliasesPackage" value="cn.itsource.ssm.domain,cn.itsource.ssm.query"/>
</bean>
1.4 Mapper接口编写
public interface BaseMapper<T> {
void save(T t);
void delete(Serializable id);
void update(T t);
T get(Serializable id);
List<T> getAll();
}
1.5 DepartmentMapper接口
public interface DepartmentMapper extends BaseMapper<Department>{
}
1.6 DomainMapper.xml文件:
在resource下建立一个和Mapper接口相同路径的包:
<mapper namespace="cn.itsource.ssm.mapper.DepartmentMapper">
<select id="get" parameterType="long"
resultType="Department">
select * from t_dept where id=#{id}
</select>
<select id="getAll"
resultType="Department">
select * from t_dept
</select>
</mapper>
1.7 配置mapper接口 ----一劳永逸
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 扫描mapper接口的包路径 -->
<property name="basePackage" value="cn.itsource.ssm.mapper" />
</bean>
1.8 Mapper的测试
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:applicationContext.xml"})
public class DepartmentMapperTest {
@Autowired
DepartmentMapper mapper;
@Test
public void testSave() {
fail("Not yet implemented");
}
@Test
public void testDelete() {
fail("Not yet implemented");
}
@Test
public void testUpdate() {
fail("Not yet implemented");
}
@Test
public void testGet() {
System.out.println(mapper.get(1L));
}
@Test
public void testGetAll() {
fail("Not yet implemented");
}
}
2.3 集成service
1. IBaseService接口
public interface IBaseService<T> {
void save(T t);
void delete(Serializable id);
void update(T t);
T get(Serializable id);
List<T> getAll();
2. BaseServiceImpl
public class BaseServiceImpl<T> implements IBaseService<T> {
@Autowired
private BaseMapper<T> baseMapper;
@Override
public void save(T t) {
baseMapper.save(t);
}
@Override
public void delete(Serializable id) {
baseMapper.delete(id);
}
@Override
public void update(T t) {
baseMapper.update(t);
}
@Override
public T get(Serializable id) {
return baseMapper.get(id);
}
@Override
public List<T> getAll() {
// TODO Auto-generated method stub
return baseMapper.getAll();
}
}
3.IDepartmentService接口
public interface IDepartmentService extends IBaseService<Department>{
}
4 DepartmentServiceImpl
@Service
public class DepartmentServiceImpl extends BaseServiceImpl<Department> implements IDepartmentService{
}
5.Service测试
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:applicationContext.xml"})
public class DepartmentServiceImplTest {
@Autowired
private IDepartmentService service;
@Test
public void testSave() {
fail("Not yet implemented");
}
@Test
public void testDelete() {
fail("Not yet implemented");
}
@Test
public void testUpdate() {
fail("Not yet implemented");
}
@Test
public void testGet() {
System.out.println(service.get(1L));
}
@Test
public void testGetAll() {
fail("Not yet implemented");
}
}
6.Controller集成Service
@Controller
@RequestMapping("/department")
public class DeptController {
@Autowired
private IDepartmentService deptService;
@RequestMapping("/index")
public String index(Model model) {
// 获取参数
// 业务操作
// 数据返回
model.addAttribute("dept","扫黄部");
return "dept/dept_index";
}
@RequestMapping("/list")
@ResponseBody
public List<Department> list() {
// 获取参数
// 业务操作
// 数据返回
System.out.println(22);
List<Department> list=deptService.getAll();
System.out.println(list);
return list;
}
}
7. Log4j集成:
log4j.rootLogger=ERROR, stdout
log4j.logger.cn.itsource.ssm=TRACE
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
其项目结构如下
这些步骤便是对SSM的集成。