Spring Boot搭建 SSM + Druid + PageHelper +JSP 的Web项目

文 | 平哥 日期 | 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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335