Spring+SpringMvc+Mybatis 5.2版本整合

Spring+SpringMvc+Mybatis 整合详细步骤

本文章基于spring5.2版本系列进行整理,具体请看下面步骤

1.新建项目
 新建一个普通的maven项目 然后 右击项目 ---》add fromwork support  ---》 添加web 依赖 
2.添加依赖
<!--依赖-->
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.1</version>
            <scope>test</scope>
        </dependency>
         <!-- Mybatis  -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.6</version>
        </dependency>
        <!-- aspectj 事务  -->
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.8.9</version>
        </dependency>
        <!-- mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.41</version>
        </dependency>
        <!-- mybatis-spring -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>2.0.5</version>
        </dependency>
        <!-- spring-jdbc -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.2.10.RELEASE</version>
        </dependency>
        <!--c3p0 -->
        <dependency>
            <groupId>com.mchange</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.5.5</version>
        </dependency>
        <!-- spring webmvc  -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.2.10.RELEASE</version>
        </dependency>
        <!-- javax.servlet-api -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
            <scope>provided</scope>
        </dependency>
        <!-- javax.servlet.jsp-api -->
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>javax.servlet.jsp-api</artifactId>
            <version>2.3.3</version>
            <scope>provided</scope>
        </dependency>
        <!-- javax.servlet/jstl -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <!-- lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
            <scope>provided</scope>
        </dependency>
        <!--fastjson -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.75</version>
        </dependency>
    </dependencies>
3.搭建项目结构
3.1 创建项目目录
  • pojo 实体类的包
  • mapper 数据访问层
  • service 逻辑业务层
  • controller 请求控制层
3.2 新建实体类
package pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
//根据数据库对应字段
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Book {
    private int bookId;
    private String bookName;
    private int bookCounts;
    private String detail;
}

3.3 创建对应mapper,service,controller
  • 在mapper 中新建 book 接口
package mapper;
import pojo.Book;
import java.util.List;
public interface BookMapper {
    //获取所有书
    List<Book> getAllBook();
}
  • 在service 中新建 BookService ,再新建包 --》impl 下 创建一个 实现类 BookServiceImpl
package service;

import pojo.Book;

import java.util.List;

public interface BookService {
    //获取所有书籍
    List<Book> getAllBook();
}

//================实现类
package service.impl;

import mapper.BookMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import pojo.Book;
import service.BookService;
import java.util.List;
//使用注解 注入bean  后面配置文件会讲到
@Service("bookService")
public class BookServiceImpl implements BookService {
    //自动注入  使用 MapperScannerConfigurer 自动生产 mapper 接口的实现类 
    @Autowired
    private BookMapper bookMapper;
    @Override
    public List<Book> getAllBook() {
        return bookMapper.getAllBook();
    }
}
  • 在controller 包下 新建BookController
package controller;

import com.alibaba.fastjson.JSON;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import service.BookService;
//这里使用到的注解都要 在配置文件中 要配置扫描
@RestController
public class BookController {
    @Autowired
    private BookService bookService;
    @RequestMapping("/getAllBook")
    public String getAllBook(){
        return JSON.toJSONString(bookService.getAllBook());
    }
}

4.新建几个配置文件
4.1新建 database.properties 配置连接数据库属性
# 使用的是 mysql 5 的连接 
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssmbook?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true
jdbc.username=root
jdbc.password=root
4.2 新建 mybatis-config.xml 这个配置文件可有可无 可在 spring中配置
<?xml version="1.0" encoding="GBK" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- 配置文件的根元素 -->
<configuration>
    <!--配置别名-->
    <typeAliases>
        <package name="pojo"/>
    </typeAliases>
    <!--注册mapper-->
    <mappers>
        <package name="mapper"/>
    </mappers>
</configuration>
4.3 新建 spring-dao.xml 主要 配置数据源,配置SqlSessionFactory,动态注入mapper 文件等等。
<?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
         http://www.springframework.org/schema/context/spring-context.xsd
            ">
    <!--关联数据库 文件-->
    <context:property-placeholder location="classpath:database.properties"/>

    <!--配置数据源-->
    <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>

    <!--配置SqlSessionFactory -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!--配置数据源 -->
        <property name="dataSource" ref="dataSource"/>
        <!--解析mybatis配置文件 -->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
        <!--可以在这里 进行mybatis 配置 例如: -->
        <property name="typeAliasesPackage" value="pojo"/>
    </bean>

    <!--动态注入mapper 文件-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
        <!-- 动态生成指定包里面的 接口的实现类  类名为该接口名 首字母为小写的名字-->
        <property name="basePackage" value="mapper"/>
    </bean>

</beans>
4.4 配置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"
       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
            ">
    <!--扫描 service包-->
    <context:component-scan base-package="service"/>
    <!--注入所有的业务类 手动注入方式  上面使用的是 注解方式   所以注释掉-->
<!--    <bean id="bookServiceImpl" class="com.service.impl.BookServiceImpl">-->
      <!-- 注入属性 ref的 bookMapper是自动生产的 通过MapperScannerConfigurer-->
<!--        <property name="bookMapper" ref="bookMapper"/>-->
<!--    </bean>-->
    <!--开启事务 注入事务注解-->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>
    <!--织入aop 等等 -->
</beans>
4.5 配置 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:mvc="http://www.springframework.org/schema/mvc"
       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/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">
    <!--注解驱动-->
    <mvc:annotation-driven/>
    <!--静态资源过滤-->
    <mvc:default-servlet-handler/>
    <!--扫描包-->
    <context:component-scan base-package="controller"/>
    <!--视图解释器  在WEB-INF 下 新建对应 jsp 文件夹-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <property name="suffix" value=".jsp"/>
    </bean>
</beans>
5.配置 web.xml
<!--配置 DispatcherServlet-->
    <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:applicationContent.xml</param-value>
        </init-param>
        <!-- 配置与tomcat 同时启动-->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>springMvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

    <!--乱码过滤 -->
    <filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
6.最后可以测试了 应为我这种方式 使用的是 @RestContoller
所以配置tomcat 启动 服务器即可 最后页面上返回的结果
[{"bookCounts":2,"bookId":6,"bookName":"????","detail":"????"},{"bookCounts":4,"bookId":19,"bookName":"java","detail":"?????"},{"bookCounts":2,"bookId":20,"bookName":"????","detail":"????"}]

最后 会出现 json 乱码 所以 这个时候还要去 spring-mvc.xml 中配置

 	<!--注解驱动-->
    <mvc:annotation-driven>
        <mvc:message-converters>
            <bean class="org.springframework.http.converter.StringHttpMessageConverter">
                <property name="defaultCharset" value="UTF-8"/>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>

最后大功告成!!!

[{"bookCounts":2,"bookId":6,"bookName":"就是大家","detail":"都很健康"},{"bookCounts":4,"bookId":19,"bookName":"java","detail":"艰苦户籍科"},
 {"bookCounts":2,"bookId":20,"bookName":"就是大家","detail":"都很健康"}]
恭喜你 已经搭建好 SSM 可以去完成你的业务了!!!!
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值