美文网首页
Spring Boot搭建 SSM + Druid + Page

Spring Boot搭建 SSM + Druid + Page

作者: 筱平哥哥 | 来源:发表于2020-09-22 18:10 被阅读0次

    文 | 平哥 日期 | 20200922

    0 Spring Boot 简介

    什么是Spring Boot

    Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can "just run".

    Spring Boot 使你可以只 “仅仅运行” 来很容易的创建基于Spring的、生产级的独立应用

    Spring Boot 特征

    • Create stand-alone Spring applications
    • Embed Tomcat, Jetty or Undertow directly (no need to deploy WAR files)
    • Provide opinionated 'starter' dependencies to simplify your build configuration
    • Automatically configure Spring and 3rd party libraries whenever possible
    • Provide production-ready features such as metrics, health checks, and externalized configuration
    • Absolutely no code generation and no requirement for XML configuration
    • 可以创建独立的Spring应用程序
    • 直接嵌入了Tomcat、Jetty、Undertow等Web 容器,所以在使用SpringBoot做Web开发时不需要部署WAR文件
    • 通过提供自己的启动器(Starter)依赖,简化项目构建配置
    • 尽量的自动配置Spring和第三方库
    • 绝对没有代码生成,也不需要XML配置文件

    1 Spring Boot 搭建SSM框架

    1.1 Idea创建项目

    利用IDEA创建Spring Boot项目:
    新建项目,选择Spring Initializr:


    新建项目

    1.2 设置项目名称、相关包信息、JDK信息

    输入项目信息:


    编辑项目信息

    1.3 选择 SSM 相关依赖

    选择SSM相关依赖,idea会自动为pom文件中添加相关依赖


    选择相关依赖

    1.4 配置数据库参数

    在配置文件:application.yml中配置数据库的驱动、url和账号密码:

    spring:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://localhost:3306/tingyu?useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false
        username: root
        password: root
    

    1.5 MyBatis 映射文件配置

    2 Spring Boot 整合Druid

    2.1 添加Druid依赖

    <!--Druid依赖-->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid-spring-boot-starter</artifactId>
        <version>1.1.10</version>
    </dependency>
    

    2.2 配置druid参数

    在配置文件application.yml中配置Druid相关参数:

    spring:
      datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        druid:
        # 连接池的配置信息
        # 初始化大小,最小,最大
          initial-size: 5
          min-idle: 5
          maxActive: 20
          # 配置获取连接等待超时的时间
          maxWait: 60000
          # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
          timeBetweenEvictionRunsMillis: 60000
          # 配置一个连接在池中最小生存的时间,单位是毫秒
          minEvictableIdleTimeMillis: 300000
          validationQuery: SELECT 1
          testWhileIdle: true
          testOnBorrow: false
          testOnReturn: false
          # 打开PSCache,并且指定每个连接上PSCache的大小
          poolPreparedStatements: true
          maxPoolPreparedStatementPerConnectionSize: 20
          # 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
          filters: stat,wall,slf4j
          # 通过connectProperties属性来打开mergeSql功能;慢SQL记录
          connectionProperties: druid.stat.mergeSql\=true;druid.stat.slowSqlMillis\=5000
          # 配置DruidStatFilter
          web-stat-filter:
            enabled: true
            url-pattern: "/*"
            exclusions: "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*"
          # 配置DruidStatViewServlet
          stat-view-servlet:
            url-pattern: "/druid/*"
            # IP白名单(没有配置或者为空,则允许所有访问)
            allow: 127.0.0.1,192.168.163.1
            # IP黑名单 (存在共同时,deny优先于allow)
            deny: 192.168.1.188
            #  禁用HTML页面上的“Reset All”功能
            reset-enable: false
            # 登录名
            login-username: admin
            # 登录密码
            login-password: 123456
    

    2.3 整合成功验证:

    启动项目后,通过浏览器访问:http://localhost:8080/druid/login.html,出现如下页面:

    Druid控制台登录页

    输入配置文件里配置的登录名和登录密码,即可访问Druid控制台:


    Druid控制台

    3 Spring Boot 整合PageHelper

    在以前自己敲的分页代码中,除了进行查询条件下的分页数据查询,还需要再进行相同条件下的数量查询,较为麻烦,PageHelper就解决了这个问题,我们只需进行正常数据查询,不需要考虑分页,通过PageHelper即可自动分页以及查询所有数据

    3.1 添加PageHelper依赖

    <!--添加pageHelper依赖-->
    <dependency>
        <groupId>com.github.pagehelper</groupId>
        <artifactId>pagehelper-spring-boot-starter</artifactId>
        <version>1.2.12</version>
    </dependency>
    

    3.2 具体使用

    Mapper层正常编写代码:
    Mapper文件:

    public interface MarriedPersonMapper {
        public List<MarriedPerson> selectMarriedPerson(@Param("pname") String pname, @Param("pphone") String pphone);
    }
    

    Mapper xml文件:

    <mapper namespace="com.gcp.mapper.MarriedPersonMapper">
        <select id="selectMarriedPerson" resultType="com.gcp.pojo.MarriedPerson">
            select * from t_married_person
            <where>
                <if test="pname!=null and pname!=''">
                    and pname like concat('%', #{pname}, '%')
                </if>
                <if test="pphone!=null and pphone!=''">
                    and pphone = #{pphone}
                </if>
            </where>
        </select>
    </mapper>
    

    在Service层代码使用PageHelper:

    public PageResult<MarriedPerson> selectMarriedPerson(Integer page, Integer rows, String pname, String pphone) {
            Page<MarriedPerson> resultPage = PageHelper.startPage(page, rows);
            List<MarriedPerson> marriedPeople = marriedPersonMapper.selectMarriedPerson(pname, pphone);
            return new PageResult<>(resultPage.getResult(),resultPage.getTotal());
        }
    

    返回的对象PageResult,有两个属性,并提供getter、setter方法:

    public class PageResult<T> {
        private List<T> rows;
        private Long total;
        // 省略构造器和getter、setter方法
    }
    

    此时进行查询,即可实现分页操作。

    4 Spring Boot 整合JSP

    4.1 引入依赖、创建目录

    引入依赖:

    <dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-jasper</artifactId>
        <scope>provided</scope>
    </dependency>
    
    

    1、在src/main目录下创建webapp目录

    2、将webapp目录设置为资源目录

    4.2 在 yml配置文件中配置视图解析器参数

    spring
    # SpringMVC 的内部资源视图解析器
      mvc:
        view:
          prefix: /WEB-INF/pages/
          suffix: .jsp
    

    4.3 编写Controller的单元方法请求转发jsp资源

    @RequestMapping("{urlPath}")
    public String publicController(@PathVariable String urlPath){
        return urlPath;
    }
    

    相关文章

      网友评论

          本文标题:Spring Boot搭建 SSM + Druid + Page

          本文链接:https://www.haomeiwen.com/subject/cdtgyktx.html