文 | 平哥 日期 | 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控制台:
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;}