Spring Boot 实战 —— 入门

Stella981
• 阅读 699

本文 Blog 地址:

简介

目前没有系统学习过 Spring 框架,参与工作时,直接参与到了 Spring Boot 项目的开发。目前还比较菜,所以,你要是和我一样,不妨也跳过 Spring 框架的学习,直接学习 Sring Boot。

官方文档的一个介绍:

Spring Boot makes it easy to create stand-alone, production-grade Spring-based Applications that you can run. We take an opinionated view of the Spring platform and third-party libraries, so that you can get started with minimum fuss. Most Spring Boot applications need very little Spring configuration.

You can use Spring Boot to create Java applications that can be started by using java -jar or more traditional war deployments. We also provide a command line tool that runs “spring scripts”.

大体意思是说,Spring Boot 可以轻松创建可以运行的独立的,基于生产级 Spring 的应用程序。这个框架简化了我们 Spring 的配置。可以使用 Spring Boot 创建 Java 应用,只需要使用 java -jarwar 包部署方式就可以启动。也内嵌了 Tomcat,在开发时无需以 war 包也可以运行应用。

环境

下面是本文编写时,我机器的环境:

  • Java 1.8.0_181
  • Maven 3.5.4

创建项目

本文目的是创建一个基本的 RESTful Web 服务。创建 Spring Boot 服务的方式主要有两种:

  • 在 IDEA 中使用 Spring Initializr 创建,我个人比较倾向这种方式,方便快捷;
  • 访问网站 Spring Initializr 网站,勾选相关项目依赖,最后生成一个初始化项目,导入 IDE。

Spring Boot 实战 —— 入门

下面主要介绍 IDEA 初始化一个 Sring Boot 项目:

1.File-New-Porject,选择 Spring Initializr,选择 SDK 版本; 2.输入项目的元数据信息,关系到项目的路径、pom 文件中项目的 Maven 坐标(GAV),;

Spring Boot 实战 —— 入门

3.选择需要的 Maven 依赖,这里 Spring Boot 版本,我选择了 2.1.6 版本;

Spring Boot 实战 —— 入门

4.最后一步指定项目存放位置;

  • src/main/java 中有项目代码文件,根目录下是入口类:SpringBootHelloWorldApplication 类。@SpringBootApplication 注解,这是整个 Spring Boot 的核心注解,它的目的就是开启 Spring Boot 的自动配置。
  • src/main/resources 下是配置文件:application.properties
  • src/test/ 下的测试入口:Chapter1ApplicationTests

添加控制器类 —— Controller

通常在项目中对外提供的 API 都会放在叫做 Controller 的包下。

我们创建一个 Controller 的包,并添加一个叫做 HelloWorld 的类:

@RestController
public class HelloWorld {


    @GetMapping("/hello")
    public String sayHello() {
        return "Hello World";
    }

}
  • @RestController 注解加在这个类上,使之变为一个 Controller

这是我们启动项目,便可以通过地址 localhost:8080/hello127.0.0.1:8080/hello 看到 sayHello 函数执行的内容。

Spring Boot 实战 —— 入门

查看控制台的输出,我们可以知道 Spring Boot 项目启动时,默认的端口是 8080

Spring Boot 实战 —— 入门

Profile

官方文档中有关于 Profile 的描述。 Prorile轮廓、外形、简况的含义,这里我就把它理解为「配置描述」好了。

在实际项目中,生产、beta 不同环境将采用不同的配置,比如数据库配置等等。这时候,我们只需要创建多分 Profile 文件即可。

除了 application.properties 文件,配置文件还可以采用下面的命名规则application-{profile}.properties。Environment 中具有一组可选的值。如果没有设置需要激活什么配置文件,就默认激活 default 配置,即 application-default.properties

指定的配置文件都是从同一个位置被激活,即从标准的配置文件 application.properties

如果指定了多个配置文件,采取 last-win 策略,即「最后获胜侧率」。这句话意思是什么呢,就是说,在你的 application.properties 中如果指定了激活好几个配置文件,那么,最后指定的那个配置文件才会生效。

我们分别创建两个环境配置文件:

  • application-dev.properties 测试环境

    server.port=8081

  • application-prod.properties 生产环境

    #server.port=8082

通过 application.prperties 指定 Profile

applcation.properties 公共配置文件。激活 Dev 配置文件,需要在 application.properties 设置:

#这里定义8080主要是为了看端口设置是否会被 dev 覆盖
server.port=8080
spring.profiles.active=dev

这时候启动程序时,我们查看控制台就可看到 Dev 环境被激活了,应用端口是 8081。这时候观察 application.properties 的端口设置是否会会生效。经过测试可以发现,此时8080 端口被 Dev 的配置覆盖了。

接着,我们激活 Prod 配置,注意,此时我将 Prod 端口配置注释掉了,这时候观察 application.properties 的端口设置是否会会生效。经过测试可以发现,此时8080 端口生效了。

通过 Environment 指定 Profile

除了上面在 application.properties 指定激活的配置外,还可以在 Envirionment 中设置相关环境变量激活:

Spring Boot 实战 —— 入门

经过测试,我在 Environment 中设置环境变量激活了 Dev 的配置,然后在 application.properties 激活的是 Prod 的配置,最终控制台日志显示, Dev 配置被激活。

jar 方式运行时

如果采用 mvn clean package 打出 jar 包,那么可以使用如下方式指定 Profile:

java -jar spring-boot-hello-world-0.0.1-SNAPSHOT.jar --spring.profiles.active=dev

Property 值获取

我们可以在 Profile 中指定一些 propety 的值,在程序中可以获取到。

application-dev.properties 定义如下:

server.port=8081
author.name=Michael

接着,我们在 Controller 类中使用 @Value 注,即可获取到这个属性:

@RestController
public class HelloWorld {
    @Value(value = "${author.name}")
    private String authorName;

    @GetMapping("/hello")
    public String sayHello() {
        return "Hello World By " + authorName;
    }

}

Spring Boot 实战 —— 入门

定制 Banner

Banner 就是指我们在启动应用时控制台一开始打印的那个内容,默认是打印 Spring Boot

  1. src/main/resorces 下新建一个名为 banner.txt 的内容;
  2. 复制你想显示的内容到 banner.txt

个性化 Banner 来源:

送一个有趣的 Banner:

////////////////////////////////////////////////////////////////////
//                          _ooOoo_                               //
//                         o8888888o                              //
//                         88" . "88                              //
//                         (| ^_^ |)                              //
//                         O\  =  /O                              //
//                      ____/`---'\____                           //
//                    .'  \\|     |//  `.                         //
//                   /  \\|||  :  |||//  \                        //
//                  /  _||||| -:- |||||-  \                       //
//                  |   | \\\  -  /// |   |                       //
//                  | \_|  ''\---/''  |   |                       //
//                  \  .-\__  `-`  ___/-. /                       //
//                ___`. .'  /--.--\  `. . ___                     //
//              ."" '<  `.___\_<|>_/___.'  >'"".                  //
//            | | :  `- \`.;`\ _ /`;.`/ - ` : | |                 //
//            \  \ `-.   \_ __\ /__ _/   .-` /  /                 //
//      ========`-.____`-.___\_____/___.-`____.-'========         //
//                           `=---='                              //
//      ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^        //
//            佛祖保佑       永不宕机     永无BUG                  //
////////////////////////////////////////////////////////////////////

补充知识

spring-boot-starter

Spring Boot 提供了很多”开箱即用“的依赖模块,都是以 spring-boot-starter-xx 作为命名的。下面列举一些常用的模块:

  • spring-boot-starter-logging :使用 Spring Boot 默认的日志框架 Logback。
  • spring-boot-starter-log4j :添加 Log4j 的支持。
  • spring-boot-starter-web :支持 Web 应用开发,包含 Tomcat 和 spring-mvc。
  • spring-boot-starter-tomcat :使用 Spring Boot 默认的 Tomcat 作为应用服务器。
  • spring-boot-starter-jetty :使用 Jetty 而不是默认的 Tomcat 作为应用服务器。
  • spring-boot-starter-test :包含常用的测试所需的依赖,如 JUnit、Hamcrest、Mockito 和 spring-test 等。
  • spring-boot-starter-aop :包含 spring-aop 和 AspectJ 来支持面向切面编程(AOP)。
  • spring-boot-starter-security :包含 spring-security。
  • spring-boot-starter-jdbc :支持使用 JDBC 访问数据库。
  • spring-boot-starter-redis :支持使用 Redis。
  • spring-boot-starter-data-mongodb :包含 spring-data-mongodb 来支持 MongoDB。
  • spring-boot-starter-data-jpa :包含 spring-data-jpa、spring-orm 和 Hibernate 来支持 JPA。
  • spring-boot-starter-amqp :通过 spring-rabbit 支持 AMQP。
  • spring-boot-starter-actuator : 添加适用于生产环境的功能,如性能指标和监测等功能。

SpringBoot 目录结构

目录结构理解

  • controller:前端控制器,负责页面访问控制,主要是对外提供的API接口,用户使用服务时的入口处,可以结合swagger生成对应的API文档
  • service:数据服务层,逻辑层,主要是业务类代码,归档了前端控制器中相关服务的操作方法接口类,该文件夹下包含子impl文件夹,归档对应的实现接口
  • domain:实体类,归档对应的实体(Entity),一个实体尝尝就对应着数据库中一张表
  • dao:数据访问层,实体类对应的数据库操作接口类,提供增删改查 MongoDB 接口
  • config:配置信息类
  • utils:工具类
  • constant:常量接口类

示例代码

参考

目录结构参考

Spring Boot 启动原理:

欢迎关注个人公众号 「iPlayMichael」

Spring Boot 实战 —— 入门

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解2016年09月02日00:00:36 \牧野(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fme.csdn.net%2Fdcrmg) 阅读数:59593
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这