前言

最近在学习SSM框架,就去找了一些视频来看,写一篇整合的文章,文章包括一些整合的依赖,以及创建的xml文件

什么是SSM框架

SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容),常作为数据源较简单的web项目的框架。

主要分为四层:

  1. 持久层:dao层(Mapper)层

主要是用来对数据进行持久化的工作,我们一般会在该层设计接口,然后从数据源获取数据,更新数据等,从而进行业务数据的处理

  1. 业务层:Service层

Service层主要是用来写一些业务逻辑。

一般Service层是调用Mapper层,然后对数据进行处理后返回给Controller控制层

  1. 控制层:Controller层

控制层一般是对用来对业务模块的控制,控制层一般是为了处理视图层发起的请求,调用Serivice层来完成请求的处理。

  1. 视图层(View):

视图层主要就是我们最常接触到的层,也是最接近用户的一层,主要负责前台的展示。

各层之间的关系,可以使用这张图来表示,表达的非常简略,主要是为了更加直观的展示各层之间的调用顺序,我们一般编写的顺序是从dao层到Service层,最后才到Controller层。

实例

下面就不对上述框架进行介绍了,直接上一个简单的整合实例以及创建。

首先我们需要创建一个maven项目,请确保你的本地仓库和配置文件都有正确配置。

pom依赖

 <groupId>org.example</groupId>
<artifactId>ssm_demo</artifactId>
<version>1.0-SNAPSHOT</version> <properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties> <dependencies>
<!-- MyBatis框架 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!-- MyBatis整合Spring -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.6</version>
</dependency>
<!-- 数据库连接 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.23</version>
</dependency>
<!-- C3P0连接池-->
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.5.2</version>
</dependency> <!-- Spring框架 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.9</version>
</dependency>
<!-- AOP -->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.9.7</version>
</dependency> <!-- Spring获取数据源-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.9</version>
</dependency> <!--Servlet、JSP、JSTL-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.3</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- JUnit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency> <!-- Lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.22</version>
<scope>provided</scope>
</dependency> <dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.6</version>
</dependency> <dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.13</version>
</dependency> </dependencies>

构建项目的路径设置

<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>

Spring 文件配置

我们先配置一个database.properties来配置连接数据源的文件,这里我就只用简单的4个基础配置,最大连接数量这些就不添加在这里了。

jdbc.Driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8&serverTimezone=Asia/Shanghai
jdbc.username=root
jdbc.password=123456

数据库文件写好了我们是不是需要配置mybatis的配置文件了,那是不是需要配置一些选项,这里我们用的是Spring来整合项目,数据库的连接池管理就交给Spring 的BeanFactory来管理了

mybatis-config.xml

<?xml version="1.0" encoding="UTF8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 配置数据源spring-->
<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
<typeAliases>
<package name="com.DY.entity"/>
</typeAliases>
<mappers>
<mapper resource="mapper/UserInfoMapper.xml"/>
</mappers> </configuration>

mappers是用来存放mapper层对应的接口配置文件,比如UserInfoMapper.xml。

配置好mybatis的文件后,我们是不是可以来配置Mapper层的文件了

spring-mapper.xml

我们需要配置连接池,通过context来获取到database.properties配置文件

<?xml version="1.0" encoding="UTF8"?>
<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/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"> <!-- 1.关联数据库配置文件-->
<context:property-placeholder location="classpath:database.properties"/> <!-- 2. 连接池-->
<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>
<!-- 3。sqlSessionFactory-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref = "dataSource"/>
<!-- 绑定配置文件-->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
</bean> <!-- 配置mapper接口扫描包,动态实现mapper接口注入Spring容器,-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
<!-- 扫描dao包-->
<property name="basePackage" value="com.DY.mapper"/>
</bean> </beans>

接着我们创建一个spring-service.xml文件来扫描service的接口文件

spring-service.xml

<?xml version="1.0" encoding="UTF8"?>
<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:aop="http://www.springframework.org/schema/aop"
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/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
">
<!-- 扫描service下的包-->
<context:component-scan base-package="com.DY.service.impl"/> <!-- 将所有的业务类,注入Spring,--> <bean id="UserInfoServiceImpl" class="com.DY.service.impl.UserInfoServiceImpl">
<property name="userInfoMapper" ref="userInfoMapper"/>
</bean> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 注入数据源-->
<property name="dataSource" ref="dataSource"/>
</bean> </beans>

我们是不是可以通过所有的业务类都注入Spring的工厂中,ref=“dataSource”,相当于在在这个Bean中注入id=dataSource这个Bean,这个我们在后面applicationContext.xml有定义,这里如果需要还可以定义Spring的AOP的配置。

那上述工作都完成后是不是可以到MVC层了,我们创建spring-mvc文件

spring-mvc.xml

<?xml version="1.0" encoding="UTF8"?>
<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-4.2.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.2.xsd"> <!-- 1.注解驱动-->
<mvc:annotation-driven/> <!-- 2.静态资源过滤-->
<mvc:default-servlet-handler/> <!-- 3.扫描包-->
<context:component-scan base-package="com.DY.controller"/> <!-- 4.视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
</beans>

这个整合的比较老,使用的还是jsp文件,这里和web.xml是配合使用的。

最后是不是可以到applicationContext.xml文件的配置了,如果前面的我们都配置的没有问题,是不是我们直接import这些配置文件进去就完成整个整合了。

<?xml version="1.0" encoding="UTF8"?>
<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/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"> <import resource="classpath:spring-mapper.xml"/>
<import resource="classpath:spring-service.xml"/>
<import resource="classpath:spring-mvc.xml"/>
</beans>

最后

这里还是展示一些相关的代码吧,比如我需要新建一个controller包、entity包、mapper包、service包,在resources下面定义一些配置文件

展示代码

controller

@Controller
@RequestMapping("/user")
public class UserInfoController {
private GetDate getDate;
@Autowired
@Qualifier("UserInfoServiceImpl")
private UserInfoService userInfoService; //查询所有用户,并返回到页面
@RequestMapping("/allUser")
public String list(Model model){
List<UserInfo> userInfos = userInfoService.querryAllUsers();
model.addAttribute("userInfos", userInfos);
return "allUser";
}
}

entity,对应着数据库的表的字段名,一般采用驼峰命名法,@Data是lombok插件的注解可以自动帮你写getter和setter方法

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor; import java.util.Date;
@Data
@AllArgsConstructor
@NoArgsConstructor public class UserInfo {
/**
* 用户ID
*/
private Long userId;
/**
*
*/
private String username;
/**
*
*/
private String userPassword; /**
*
*/
private Date createTime;
/**
*
*/
private Date updateTime; }

mapper, 展示一个UserInfoMapper

包括一些方法,和一些参数的获取

package com.DY.mapper;

import com.DY.entity.UserInfo;
import org.apache.ibatis.annotations.Param; import java.util.List; public interface UserInfoMapper {
/**
* 增加用户
*/
// int addUser(UserInfo userInfo); /**
* 查询用户
*/
UserInfo querryUserById(@Param("userId") Long userId); /**
* 查询所有用户
* DY
* @return
*/
List<UserInfo> querryAllUsers(); /**
* 增加用户
* @param userInfo
* @return
*/
Integer insertUserInfo(UserInfo userInfo); /**
* 更新用户
*/
Integer updateUserInfo(UserInfo userInfo); /**
* 根据用户姓名查询用户
* @param userName
* @return
*/
List<UserInfo> querryUserByUserName(@Param("userName") String userName); }

service层
service一般会分成两个部分,一个是接口部分,一个是这个接口的实现Impl包

比如这里我先展示UserInfoService

package com.DY.service;

import com.DY.entity.UserInfo;
import org.apache.ibatis.annotations.Param; import java.util.List; public interface UserInfoService {
UserInfo querryUserById(@Param("userId") Long userId); /**
* 查询所有用户
* DY
* @return
*/
List<UserInfo> querryAllUsers(); /**
* 插入一个新用户
* @return
*/
Integer insertUserInfo(UserInfo userInfo); /**
* 更新用户信息
* @param userInfo
* @return
*/
Integer updateUserInfo(UserInfo userInfo); /**
* 根据用户姓名查询用户
*/
List<UserInfo> querryUserByUserName(String userName);
}

这里是不是有一些业务逻辑的接口方法,对应的Impl类

UserInfoServiceImpl.java,需要@Autowired使用自动装载,将mapper层的注入到Service中,方便我们调用Mapper层的方法

package com.DY.service.impl;

import com.DY.entity.UserInfo;
import com.DY.mapper.UserInfoMapper;
import com.DY.service.UserInfoService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import java.util.List; @Service
public class UserInfoServiceImpl implements UserInfoService {
//service层组合mapper,
@Autowired
private UserInfoMapper userInfoMapper; public void setUserInfoMapper(UserInfoMapper userInfoMapper) {
System.out.println("设置mapper");
this.userInfoMapper = userInfoMapper;
} @Override
public UserInfo querryUserById(Long userId) { return this.userInfoMapper.querryUserById(userId);
} @Override
public List<UserInfo> querryAllUsers() { return this.userInfoMapper.querryAllUsers();
} @Override
public Integer insertUserInfo(UserInfo userInfo) {
System.out.println(userInfo);
return this.userInfoMapper.insertUserInfo(userInfo);
} @Override
public Integer updateUserInfo(UserInfo userInfo) {
System.out.println(userInfo);
return this.userInfoMapper.updateUserInfo(userInfo);
} @Override
public List<UserInfo> querryUserByUserName(String userName) {
System.out.println(userName);
return this.userInfoMapper.querryUserByUserName(userName);
}
}

总结

到这里,基本的整个项目的整合就结束了,可能写的还不是很清楚,只是我的粗略理解,刚学望各位大佬指点。

SSM整合之基础xml文件以及基础理解的更多相关文章

  1. ssm整合的spring.xml文件配置(applicationContext.xml)

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  2. ssm整合之springmvc.xml文件

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  3. ssm整合之web.xml文件

    <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" " ...

  4. 配置ssm 时, web.xml 文件无 # 自动代码提示

    环境:STS 版本:spring-tool-suite-3.8.1.RELEASE-e4.6-win32-x86_64 配置ssm 时, web.xml 文件无 如下图蓝色圈范围内的提示 问题与 链接 ...

  5. 【报错】spring整合activeMQ,pom.xml文件缺架包,启动报错:Caused by: java.lang.ClassNotFoundException: org.apache.xbean.spring.context.v2.XBeanNamespaceHandler

    spring版本:4.3.13 ActiveMq版本:5.15 ======================================================== spring整合act ...

  6. 关于mybatis-config.xml文件的基础解释

    今天是我第一天落户博客园,想一想从mybatis框架开始写起吧.mybatis框架与Hibernate框架相比来说,专注于SQL语句,对SQL语句的要求比较高吧. 我觉得,对于mybatis框架来说, ...

  7. ssm整合(基于xml配置方式)

    本文是基于xml配置的方式来整合SpringMVC.Spring和Mybatis(基于注解的方式会再写一篇文章),步骤如下: (1)首先自然是依赖包的配置文件 pom.xml <project ...

  8. Spring整合Hibernate的XML文件配置,以及web.xml文件配置

    利用Spring整合Hibernate时的XML文件配置 applicationContext.xml <?xml version="1.0" encoding=" ...

  9. SSM 生成mapper中xml文件:未能解析映射资源:“文件嵌套异常

    错误日记我就网上随便找个贴着: 错误一: org.springframework.beans.factory.BeanCreationException: Error creating bean wi ...

  10. SSM整合的pom.xml依赖

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

随机推荐

  1. IIR数字滤波器的设计

    IIR数字滤波器的设计 Mrakdown常见数学符号 Markdown基础语法 冲激响应不变法 冲激响应不变法:就是用其单位冲激响应序列模仿模拟滤波器的单位冲激响应的抽样值 设计的具体步骤及方法 ​ ...

  2. WebPack之懒加载原理

    代码结构 main.js console.log("这是main页面"); import(/* webpackChunkName: "foo" */" ...

  3. C语言的导数和积分

    用C进行导数和积分的运算 进行求导 设一个dx,利用f(x)-f(x-dx)/dx或f(x)-f(x+dx)/dx进行计算. float qd(float x) { float dx=0.01,y; ...

  4. CC协议的诞生背景

    CC协议的诞生背景 在当今世界绝大部分国家的法律法规中,作品的版权一般都保留于创造者或拥有人手中,在没有特殊声明的情况下,任何人想要获取或使用该作品,都要事先取得版权所有者的授权,才可以进行合法的获取 ...

  5. 手写 Java HashMap 核心源码

    手写 Java HashMap 核心源码 手写 Java HashMap 核心源码 上一章手写 LinkedList 核心源码,本章我们来手写 Java HashMap 的核心源码. 我们来先了解一下 ...

  6. k8s集群角色管理

    查看集群各节点角色: [root@k8s-master-2 ~]# kubectl get nodes NAME STATUS ROLES AGE VERSION k8s-master-1 Ready ...

  7. Android笔记-跳转到相册选择图片

    跳转到相册选择图片 即设置一个点击事件,点击之后即可跳转到相册进行图片的选择 具体的实现步骤: 界面很简单的啦,这里就直接将源代码放出来啦: <?xml version="1.0&qu ...

  8. Python学习笔记--PySpark的基础学习(二)

    filter方法(过滤想要的数据进行保留) 具体实现(保留奇数): 具体实现(保留偶数): distinct方法(对RDD进行去重,返回新的RDD) 且无需传参 具体实现(去重): sortBy方法( ...

  9. CF1286F Harry The Potter

    CF1286F Harry The Potter 首先答案上界为 \(n\),就是对每个点用一次操作 1. 那么我们现在的思维模式就是利用操作 2 来减少操作 1 的次数. 不难发现,如果操作 2 的 ...

  10. Java 遍历方式

    一.遍历方式 迭代器 增强for循环 普通for循环 二.使用 迭代器: public class IteratorMethod { public static void main(String[] ...