手把手教你搭建 SSM 框架(Eclipse 版)
本期文章欲带大家实现 SSM(Spring+SpringMVC+MyBatis)框架的 Web 我的项目,通常也称为三大框架做整合。在开始教程之前,先来了解下 SSM 的概念。
原文来自集体公众号【C you again】,若有须要,请在公众号后盾私信!!
Spring 就像是整个我的项目中拆卸 Bean 的大工厂,在配置文件中能够指定应用特定的参数去调用实体类的构造方法来实例化对象,它有两个外围别离是 IOC(管制反转)和 AOP(面向切面编程)。IOC 意为管制反转,简略的了解就是将应用 new 关键字创建对象的权力交给 Spring 框架来治理,开发者更专一于业务逻辑的实现。AOP 意为面向切面编程,通过预编译形式和运行期间动静代理实现程序性能的对立保护的一种技术,利用 AOP 能够对业务逻辑的各个局部进行隔离,从而使得业务逻辑各局部之间的耦合度升高,进步程序的可重用性,同时进步了开发的效率,事务管理、日志文件打印通常都会用到 AOP。
SpringMVC 是 Spring 框架的一个模块,是一个基于 MVC 的 Web 框架,能够说它是前后端数据传输的桥梁。
MyBatis 是一款优良的长久层框架,它反对定制化 SQL、存储过程以及高级映射。MyBatis 防止了简直所有的 JDBC 代码和手动设置参数以及获取后果集,能够应用简略的 XML 或注解来配置和映射原生信息,将接口和 Java 的 Pojo(Plain Ordinary Java Object,一般的 Java 对象) 映射成数据库中的记录。
好了,看完以上概念,咱们就正式开始明天的教程了。制作不易,多多转发分享哦!!
1、新建动静 Web 我的项目
本教程用到 Eclipse 开发工具,所以 JDK、开发工具都是要提前装置配置好的。
File–>New–>Project–>Dynamic Web Project
输出项目名称(本教程我的项目名:ssmDemo),最初点击 Finish 即可。
2、补充、欠缺我的项目目录
为使得我的项目合乎 MVC 开发标准,咱们须要在 src 下新建 controller、service、mapper、entity 几个包和 resources 目录。实现后目录构造如下图:
3、导入所需 Jar 包
如果你装置了 Maven 插件,导入 Jar 包的事件就交给它去做了,你只须要退出相干依赖即可。本期教程用最原始的办法导入我的项目所需 Jar 包。手动导入会存在 Jar 包版本抵触等很多问题,倡议间接下载应用,下载地址在公众号【C you again】后盾回复“Jar”自行下载,若不能失常下载,请在后盾私信。
首先将下载好的 Jar 包复制到 WebContent–>WEB-INF–>lib 文件夹下,而后选中所有 Jar 包 –> 鼠标右击 –>Build Path–>Add to Build Path。
4、增加相干配置文件
实现以上根本步骤后,接下来就是 SSM 整合的关键步骤了。
首先在我的项目的 WebContent–>WEB-INF 下的 web.xml 文件中退出以下配置,如果没有 web.xml 文件就须要本人新建一个。
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID" version="2.5">
<welcome-file-list>
<welcome-file>test.jsp</welcome-file>
</welcome-file-list>
<!-- 加载 spring 容器 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:application.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 解决 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>
<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:springmvc.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>
</web-app>
实现 web.xml 的配置后,在后面建好的 resources 文件夹下新建 application.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-3.1.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.1.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 主动扫描 -->
<context:component-scan base-package="com.cya"/>
<!-- 引入配置文件 -->
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<value>classpath:dbconfig.properties</value>
</property>
</bean>
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="driverClassName" value="${jdbc.driver}" />
<property name="maxActive" value="10" />
<property name="minIdle" value="5" />
</bean>
<!-- spring 和 MyBatis 整合 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<!--mybatis 分页插件 -->
<property name="configLocation" value="classpath:mybatis.xml"></property>
<!-- 主动扫描 mapping.xml 文件 -->
<property name="mapperLocations" value="classpath*:com.cya.mapper/*.xml"></property>
</bean>
<!-- DAO 接口所在包名,Spring 会主动查找其下的类 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.cya.mapper"/>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
<!-- 事务管理 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!-- 反对事务注解的(@Transactional)-->
<tx:annotation-driven transaction-manager="transactionManager"/>
</beans>
接着在 resources 文件夹下新建 springmvc.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 主动拆卸 -->
<context:component-scan base-package="com.cya.controller" />
<!-- 启用 spring mvc 注解 -->
<mvc:annotation-driven />
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 前缀 -->
<property name="prefix" value="/WEB-INF/"/>
<!-- 后缀 -->
<property name="suffix" value=".jsp"></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>
</beans>
同下面的步骤,持续在 resources 文件夹下新建 mybatis.xml 和 dbconfig.properties。
mybatis.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>
</configuration>
dbconfig.properties 文件:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test?characterEncoding=utf-8
jdbc.username=root
jdbc.password=
至此,所有的整合步骤曾经实现了,最初的目录构造如下所示,接下来就是设计测试用例了。
5、测试 Web 是否失常运行
实现上述步骤后,接下来就测试下整合是否胜利吧!
在 WebContent 文件夹下新建 test.jsp。
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title> 测试 SSM 整合 </title>
</head>
<body>
<h3>
<a href="test"> 获取 Person 信息 </a>
</h3>
</body>
</html>
新建数据库 test,在 test 库中建表 person(id,name,age)
在 src–>com.cya.entity 下创立 Person.java 实体类
package com.cya.entity;
public class Person {
private int id;
private String name;
private int age;
public int getId() {return id;}
public void setId(int id) {this.id = id;}
public String getName() {return name;}
public void setName(String name) {this.name = name;}
public int getAge() {return age;}
public void setAge(int age) {this.age = age;}
}
在 src–>com.cya.mapper 下创立 IPersonMapper.java 接口和 IPersonMapper.xml。注:这两个文件名必须要统一!
IPersonMapper.java 接口:
package com.cya.mapper;
import java.util.List;
import com.cya.entity.Person;
public interface IPersonMapper {public List<Person> getPerson();
}
IPersonMapper.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="com.cya.mapper.IPersonMapper">
<select id="getPerson" resultType="com.cya.entity.Person">
select * from person
</select>
</mapper>
在 src–>com.cya.service 下创立 IPersonService.java 接口。
package com.cya.service;
import java.util.List;
import com.cya.entity.Person;
public interface IPersonService {public List<Person> getPerson();
}
在 src 下新建 com.cya.service.impl 包,并创立 PersonServiceImpl.java 类实现 IPersonService.java 接口中的 getPerson() 办法。
package com.cya.service.impl;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.cya.entity.Person;
import com.cya.mapper.IPersonMapper;
import com.cya.service.IPersonService;
@Service()
public class PersonServiceImpl implements IPersonService{
@Autowired
private IPersonMapper personMapperImpl;
@Override
public List<Person> getPerson() {
// TODO Auto-generated method stub
return personMapperImpl.getPerson();}
}
在 src–>com.cya.controller 包下新建 class,这里取名为 Test.java,去调用 PersonServiceImpl.java 中的 getPerson() 办法。
package com.cya.controller;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.cya.entity.Person;
import com.cya.service.IPersonService;
@Controller
@ResponseBody
public class Test {
@Resource
private IPersonService personServiceImpl;
@RequestMapping("test")
public List<Person> getPerson() {return personServiceImpl.getPerson();
}
}
最初查看代码,启动服务,在浏览器地址栏输出:localhost:8080//ssmDemo/test.jsp 查看成果。
本期分享就到这里,因自己技术无限,文章难免会呈现一些谬误,欢送斧正。创作不易,大家多多转发点赞,感激。