前言
上一周本来已经分别将Spring、SpringMVC、MyBatis得搭建记录下了。所以这个整合原本就不打算写得,但是今天想了一下还是记录下来一个全得,方便下次直接查阅和复习。因此,这里就不再赘述一个功能说明,直接记录代码了。此时,我会边写代码,边记录。
一、创建Maven项目
使用Eclipse创建一个Maven项目,注意是war包。
创建好了之后,会有报错,是因为没有生成web.xml。
将视图调整为project explorer,在项目得deployment descriptor上右键,点击generater deployment descriptor sutb即可。*
*
二、导包
导包的列表如下。
javax.annotation-api是用于使用Resource注解的,如果要使用Autowire可以不导入。
javax.servlet-api是用于使用HttpservletRequest的。因为我没有用tomcat的包,此处需要引入,这个看自己的情况。
其他的都需要。
三、导入xml文件
有两个xml需要导入,一个是Spring的xml。一个是mybatis的sqm映射xml。
因为里面有相应的命名空间之类的信息,不太容易也不需要记住,需要使用时导入进来就可以了。
spring.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:jdbc="http://www.springframework.org/schema/jdbc"
xmlns:jee="http://www.springframework.org/schema/jee"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xmlns:util="http://www.springframework.org/schema/util"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd
http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd">
</beans>
Mapper.xml:
这里的根据业务要求编写,比如EmpMapper.xml
<?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>
四、代码编写
整合ssm,也需要一步步的写,在一边写的时候一边测试,我就是先写的spring的配置,在写的springMVC的,再写的mybatis的。当然,这是我的顺序,大家可以根据自己的喜好来写。
这里我就直接放代码了。
实体类Emp:
public class Emp implements Serializable{
private String id;
private String name;
private Integer age;
private boolean sex;
public String getId() {
return id;
}
public String getName() {
return name;
}
public Integer getAge() {
return age;
}
public boolean isSex() {
return sex;
}
public void setId(String id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public void setAge(Integer age) {
this.age = age;
}
public void setSex(boolean sex) {
this.sex = sex;
}
@Override
public String toString() {
return "Emp [id=" + id + ", name=" + name + ", age=" + age + ", sex=" + sex + "]";
}
}
mapper映射器(dao接口)
public interface EmpDao {
public List<Emp> selectAll();
}
service接口及其实现类
service接口:
public interface EmpService {
public List<Emp> selectAll();
}
serviceImpl实现类:
@Service
public class EmpServiceImpl implements EmpService{
@Autowired
private EmpDao empDao;
public List<Emp> selectAll(){
return empDao.selectAll();
}
}
控制器controller
@Controller
public class EmpController {
@Autowired
private EmpService empService;
@RequestMapping("select")
@ResponseBody
public String Select(){
List<Emp> emplist = empService.selectAll();
return emplist.toString();
}
}
DispatcherServlet
<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.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>
spring.xml
<!-- spring 组件扫描 -->
<context:component-scan base-package="com" />
<!-- 视图解析器 ViewResolver -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="WEB-INF/jsp/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 获取连接池配置 -->
<util:properties id="dbconfig" location="classpath:db.properties" />
<!-- 配置连接池 -->
<bean id="dbcp" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="#{dbconfig.driver}"></property>
<property name="url" value="#{dbconfig.url}"></property>
<property name="username" value="#{dbconfig.username}"></property>
<property name="password" value="#{dbconfig.password}"></property>
</bean>
<!-- 配置SqlSessionFactory -->
<bean id="ssfb" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dbcp"></property>
<!-- 所有SQL映射文件的地址 -->
<property name="mapperLocations" value="classpath:mapper/*.xml"></property>
</bean>
<!-- MapperScannerConfigurer等价于SqlSession.getMapper() -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 标注映射器的地址 -->
<property name="basePackage" value="com.zdl.dao"></property>
</bean>
数据库连接配置
driver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@localhost:1521:orcl
username=zdl
password=zhangdl
测试结果
页面上输出如下内容:
[Emp [id=1, name=zs, age=20, sex=true], Emp [id=2, name=ls, age=18, sex=false]]
搭建成功!
补充
本项目因为只是一个最基础的ssm框架,暂时未使用到静态资源,上传文件等,因此未用到如下配置,如有需要,请自行加入。
<!-- 注册MVC注解驱动 -->
<mvc:annotation-driven />
<!-- 静态资源可访问的设置方式 -->
<mvc:default-servlet-handler />
<!--避免IE执行AJAX时,返回JSON出现下载文件 -->
<bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>text/html;charset=UTF-8</value>
</list>
</property>
</bean>
<!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 -->
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
<property name="messageConverters">
<list>
<ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON转换器 -->
</list>
</property>
</bean>
<!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 默认编码 -->
<property name="defaultEncoding" value="utf-8" />
<!-- 文件大小最大值 -->
<property name="maxUploadSize" value="10485760000" />
<!-- 内存中的最大值 -->
<property name="maxInMemorySize" value="40960" />
</bean>
web.xml
<!-- 编码过滤器 -->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<async-supported>true</async-supported>
<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>
结束语
通过这个案例,我发现很多时候确实要上手才能知道其中的酸甜苦辣,原本以为上周已经过了一遍,很熟悉了,但是再次搭建的时候,有些地方还是会犹豫。熟能生巧嘛。希望以后能够多多的动手操作。
近期,我会再整理一下springboot搭建ssm框架。那就会比这简单多了。