目录
1. 创建项目
2. 导入所依赖的 jar 包
3. 配置MyBatis
4. 配置spring事务管理
5. 配置Spring
* Spring配置代码解读
6. dao层
7. mappers映射文件
8. common层
9. service层
10. web层
11. 测试
ssm大合体!
1. 创建项目
📍创建一个JavaEE项目
不会创建JavaEE项目的小可爱可以回家种地了~~
📍创建所要用到的包和配置文件:
2. 导入所依赖的 jar 包
📍在pom.xml配置文件中引入依赖:
<!-- spring-context -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
<!-- spring-jdbc-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
<!-- mysql组件-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.16</version>
</dependency>
<!--阿里数据源 数据库连接管理组件-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.10</version>
</dependency>
<!-- mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.2</version>
</dependency>
<!-- spring集成mybatis jar-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.1</version>
</dependency>
<!--aspectj-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
<!-- Spring Web-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
3. 配置MyBatis
📍在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>
<settings>
<!-- 日志 -->
<setting name="logImpl" value="STDOUT_LOGGING"/>
<!-- 开启数据库列名与java属性名转换,例如user_name userName -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
<!-- 全局二级缓存开关 -->
<setting name="cacheEnabled" value="true"/>
</settings>
<typeAliases>
<!--为类配置别名-->
<package name="com.ffyc.ssmpro.model"/>
</typeAliases>
</configuration>
4. 配置spring事务管理
📍在webapp目录下的WEB-INF文件夹中的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">
<servlet>
<servlet-name>application</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>0</load-on-startup>
</servlet>
<!--请求映射-->
<servlet-mapping>
<servlet-name>application</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
5. 配置Spring
📍在spring.xml文件配置
<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" xmlns:tx="http://www.springframework.org/schema/tx"
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
https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/aop https://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/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<context:component-scan base-package="com.ffyc.ssmpro"></context:component-scan>
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/ssmdb?serverTimezone=Asia/Shanghai"></property>
<property name="username" value="root"></property>
<property name="password" value="root"></property>
<property name="initialSize" value="10"></property><!--初始化连接数量-->
<property name="maxActive" value="20"></property><!--最大连接数量-->
</bean>
<!-- Spring管理生成sqlSessionFactory对象 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="configLocation" value="classpath:mybatis.xml"></property>
<property name="mapperLocations" value="classpath:mappers/*Mapper.xml">
</property>
</bean>
<!-- 生成dao包下所有接口的代理对象 -->
<bean id="mapperFactory" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.ffyc.ssmpro.dao"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
<!--开启自动代理-->
<aop:aspectj-autoproxy />
<!--配置Spring事务管理器-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 开启注解事务管理 -->
<tx:annotation-driven transaction-manager="transactionManager"/>
<!-- 开启web层注解 -->
<mvc:annotation-driven></mvc:annotation-driven>
</beans>
* Spring配置代码解读
1. 如图所示:
<context:component-scan base-package="com.ffyc.ssmpro">
:指示 Spring 在com.ffyc.ssmpro
包及其子包中扫描带有特定注解(如@Component
、@Service
、@Repository
等)的类,并将它们自动注册为 Spring 容器中的 bean。
2. 如图所示::
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
:定义了一个名为dataSource
的数据源 bean,使用阿里巴巴的 Druid 数据库连接池。配置了数据库驱动类、连接 URL、用户名、密码以及连接池的初始化连接数量和最大连接数量等属性。
3. 如图所示:
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
:配置 MyBatis 的SqlSessionFactory
,它用于创建与数据库交互的SqlSession
。
dataSource
属性引用了上面定义的数据源 bean,确保 MyBatis 使用正确的数据库连接。configLocation
属性指定了 MyBatis 的配置文件mybatis.xml
的位置。
mapperLocations
属性指定了 MyBatis 的 Mapper XML 文件的位置,这里是classpath:mappers/*Mapper.xml
,表示在类路径下的mappers
包中查找所有以Mapper.xml
结尾的文件。
4.如图所示
<bean id="mapperFactory" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
:使用 MyBatis-Spring 提供的MapperScannerConfigurer
来自动扫描com.ffyc.ssmpro.dao
包下的所有接口,并为它们生成代理对象。这些代理对象可以直接注入到其他 bean 中,方便进行数据库操作。
basePackage
属性指定了要扫描的包路径。
sqlSessionFactoryBeanName
属性指定了用于创建代理对象的SqlSessionFactory
的 bean 名称。
5. 如图所示
<aop:aspectj-autoproxy />
:开启 AspectJ 风格的自动代理,使得可以在 Spring 中使用 AOP 进行横切关注点的分离,例如事务管理、日志记录等。
6. 如图所示:
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
:配置 Spring 的事务管理器,这里使用DataSourceTransactionManager
,它依赖于数据源来管理事务。dataSource
属性引用了前面定义的数据源 bean。
<tx:annotation-driven transaction-manager="transactionManager"/>
:开启注解驱动的事务管理,使得可以使用@Transactional
注解在方法上标记需要事务管理的操作。
7. 如图所示:
<mvc:annotation-driven></mvc:annotation-driven>
:开启 Spring MVC 的注解驱动,使得可以在控制器类和方法上使用@Controller
、@RequestMapping
等注解来处理 Web 请求。
6. dao层
📍创建一个LoginDao接口
import com.ffyc.ssmpro.model.Admin;
public interface LoginDao {
Admin login(Admin admin);
}
7. mappers映射文件
📍创建LoginMapper.xml映射文件,负责执行sql语句
<?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.ffyc.ssmpro.dao.LoginDao">
<select id="login" parameterType="Admin" resultType="Admin">
select * from admin where account=#{account} and password = #{password}
</select>
</mapper>
8. common层
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
@Component
@Aspect
public class CommonUtil {
@AfterThrowing(value = "execution(* com.ffyc.ssmpro.web.*.*(..))",throwing="throwable")
public void exception(Throwable throwable){
System.out.println("系统忙"+throwable.getMessage());
}
}
9. service层
import com.ffyc.ssmpro.dao.LoginDao;
import com.ffyc.ssmpro.model.Admin;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service
@Transactional(rollbackFor = Exception.class)
public class LoginService {
@Autowired
LoginDao loginDao;
public Admin login(Admin admin){
Admin admin1 = loginDao.login(admin);
return admin1;
}
}
10. web层
import com.ffyc.ssmpro.service.LoginService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping(path = "/loginCtl") //为类和方法定义地址
public class LoginController {
@Autowired
LoginService loginService;
@RequestMapping(path = "/login")
public String login(){
System.out.println("登录");
return "success";
}
}
11. 测试
📍在浏览器通过后端地址访问:
📍成功访问!
海漫浩浩,我亦苦作舟!大家一起学习,一起进步!