SpringBoot学习笔记【part05】开发技巧

本文介绍SpringBoot应用的编写流程,包括引入场景依赖、查看自动配置、配置修改及自定义组件等步骤。同时涵盖Lombok简化JavaBean开发的方法,dev-tools热部署的使用,以及SpringInitializer项目初始化向导的应用。
摘要由CSDN通过智能技术生成

SpringBoot 学习笔记 Part05

1. 总结SpringBoot应用如何编写

在以后的springboot开发,遵循以下总结的步骤,就会变成非常简单了。

  • 第一步:引入场景依赖

    如要开发缓存或者消息队列,我们就要去找是否springboot或是第三方有这个场景依赖。
    springboot官方的场景依赖:https://docs.spring.io/spring-boot/docs/current/reference/html/using.html#using.build-systems.starters

  • 第二步:查看自动配置了哪些(选做)

    引入场景对应的自动配置一般都默认生效了。但除了前往底层源码,是否还有方法能查看哪些已配置、哪些没配置呢?

    方法:配置文件 application.properties 中写入 debug=true 开启自动配置报告。

    属性:Negative matches(不生效的)、Positive matches(生效的)

  • 第三步:部分配置是否需要修改

    如数据库的账号密码配置,肯定是需要我们自己去完成的。除了前往底层源码找 key 值,我们还可以去官方的参照文档查找具体的修改配置项: https://docs.spring.io/spring-boot/docs/current/reference/html/application-properties.html#application-properties
    最后在 application.properties 里重写修改。

  • 第四步:自定义添加组件

    使用 @Bean、@Component 加入自己编写的组件,

    加入 xxxCustomizer 自定义器,来对已有组件进行自定义,


2. Lombok

Lombok 用于简化 JavaBean 的开发。

第一步:首先引入 Lombok 的依赖。(之前学习过,springboot默认已有各个jar包的版本号,不写则默认,写了则重写)

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
</dependency>

第二步:idea 安装 Lombok 插件。

在这里插入图片描述


2.1 @Data注解

当我们用@Data标注一个JavaBean类后,getter、setter方法就不用每个都去书写了,Lombok会为我们在编译时自动生成,保持源代码页面的干净整洁。

@Data
public class User {
    private String name;
    private Integer age;
    private Pet pet;

}

2.2 @ToString

编译时自动生成toString方法。

@ToString
public class User {
    private String name;
    private Integer age;
    private Pet pet;

}

2.3 @AllArgsConstructor、@NoArgsConstructor

@AllArgsConstructor 编译时自动生成全参构造器、@NoArgsConstructor编译时自动生成无参构造器。自定义构造器则需要自己编写。

@NoArgsConstructor
@AllArgsConstructor
public class User {
    private String name;
    private Integer age;
    private Pet pet;

}

2.4 @EqualsAndHashCode

@EqualsAndHashCode 编译时自动重写这个类的 equals 方法和 hashCode 方法。

@EqualsAndHashCode
public class User {
    private String name;
    private Integer age;
    private Pet pet;

}

2.5 @Slf4j

注入日志类,被标注的类中可以使用一个变量 log(无需声明,有注解则可用),使用该变量能实现日志的许多功能。后面我们的开发会经常使用到日志,使用@Slf4j会变得非常方便。

@Slf4j
@RestController
public class HelloController {

    @RequestMapping("hello")
    public String handle01(){

        log.info("日志写进来了");

        return "Hello SpringBoot 2 !";
    }
}


3. dev-tools

dev-tools 用于项目的热部署,尤其是web应用,页面文件修改后会立即生效,但类文件修改后不会立即生效。

引入依赖坐标。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
    <optional>true</optional>
</dependency>

快捷键 ctrl + F9 生效。

dev-tools 本质上还是重启服务器,但为什么重启会更快,因为重启的时候只加载了在开发的Class,并没有重新加载第三方的jar包。若有需要可以考虑付费的 Jrebel ,这个插件会为我们动态地只替换那些修改过的类。


4. Spring Initailzr(项目初始化向导)

第一步:在idea里创建新项目时,使用Spring Initailzr。

在这里插入图片描述


第二步:勾选我们需要的场景,idea为我们自动导入。(以web、mybatis、redis为例)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


第三步:点击创建,idea会联网为我们把starters场景都下载下来。其中还默认安装了了单元测试和打包插件,创建了主类的全局配置文件application.properties,并创建了完整的项目结构。

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Parker7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值