Spring+SpringWeb+MyBatis三大框架整合教程 实现先前后端交互搭建

目录

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. 测试

📍在浏览器通过后端地址访问:

📍成功访问!




 海漫浩浩,我亦苦作舟!大家一起学习,一起进步! 

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值