Java SpringBoot开发小技巧详解

时间:2022-09-06 18:30:05

一、SpringBoot开发小技巧

1.1 Lombok

作用:在程序编译的时候,自动帮我们生成setter和getter方法以及我们的toString方法和我们的全参和无参构造器等等。

那么,怎么用呢?很简单,用下边这四个注解就行了:

1、@Data:自动生成setter和getter方法。

2、@ToString:自动生成toString方法。

3、@AllArgsConstructor:自动生成全参构造器

4、@NoArgsConstructor:自动生成无参构造器

5、@EqualsAndHashCode:自动生成EqualsAndHashCode方法

6、@Slf4j:开启我们的日志记录器

使用Lombok,首先当然要引入他的依赖,这个在SpringBoot也装配好了,所以我们不用写他的版本号。

      <!--lombok依赖-->
      <dependency>
          <groupId>org.projectlombok</groupId>
          <artifactId>lombok</artifactId>
      </dependency>

然后在IDEA的settings中下载Lombok的插件。(下载完记得重启一下IDEA,让他生效)

Java SpringBoot开发小技巧详解

使用这个插件后,我们以后开发的时候的那些Bean,我们只需要在上面添加如下注解就可以生成对应的方法了:

package com.example.bean;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

@Data                   //setter和getter方法
@ToString               //toString方法
@AllArgsConstructor     //有参构造器
@NoArgsConstructor      //无参构造器
@EqualsAndHashCode		//EqualsAndHashCode方法
public class User {
  private Integer id;
  private String username;
  private String password;
}

然后我们给控制器也写一个@Slf4j注释

package com.example.controller;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

//@RestController可以理解成是Controller加ResponseBody
@RestController
@Slf4j
public class HelloController {

  @RequestMapping("/hello")
  public String toHello(@RequestParam("name") String name){
      log.info("/hello被人访问啦!");
      return "Hello,World!"+name;
  }
}

在主程序中写上:

package com.example.boot;

import com.example.bean.User;
import com.example.config.MyConfig;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;

/**
* 主程序类
* @SpringBootApplication 告诉 SpringBoot这是一个SpringBoot应用
*/
@SpringBootApplication(scanBasePackages = "com.example")
public class MainApplication {
  public static void main(String[] args) {
      //固定写法
      ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args);
      
      MyConfig myConfig = run.getBean(MyConfig.class);
      //通过myConfig的方法获取Bean
      User user = myConfig.user();
//        User user1 = myConfig.user();
      //通过run获取Bean
      User user2 = run.getBean("user",User.class);
      System.out.println(user);
      System.out.println(user2);
  }
}

运行我们的主程序,我们来测试一下,首先Bean的创建没问题,而且他的toString方法也没问题。

Java SpringBoot开发小技巧详解

登录http://localhost:8888/hello?name=哈哈哈

Java SpringBoot开发小技巧详解

控制台输出也没问题。

Java SpringBoot开发小技巧详解

1.2 dev-tools

作用:以前开发页面啥的,老要重启一下主程序或者重启一下Tomcat服务器,有了他就方便多啦。我们只需要按Ctrl+F9(编译一下),就可以让他实时生效。(第一次使用记得在成功导入依赖后,先重启一次主程序)

先添加依赖:

      <!--dev-tools依赖-->
      <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-devtools</artifactId>
          <optional>true</optional>
      </dependency>

然后我们来试一下,我们把之前设置端口号为8888的那一段删掉,让他变回默认的8080。按Ctrl+F9,很快就编译完成了,然后我们此时登录8080端口号成功。登录8888端口号就不行了。开发网页啥的时候也是一样,改完代码,直接编译,然后回去网站刷新一下即可。

Java SpringBoot开发小技巧详解

1.3 Spring Initializr

作用:初始化我们的SpringBoot工程。

在IDEA中,我们新建我们的项目,可以选择Spring Initializr,然后配置我们的工程名、路径等等信息,大致如下:

Java SpringBoot开发小技巧详解

Java SpringBoot开发小技巧详解

完成后,他就会自动帮我们导入我们的依赖

Java SpringBoot开发小技巧详解

Java SpringBoot开发小技巧详解

并且帮我们设计好我们的项目结构:

Java SpringBoot开发小技巧详解

主程序类也帮我们写好了默认的语句。

Java SpringBoot开发小技巧详解

如此,开发者基本上就只需要写自己的那些dao、service、controller和bean一系列的业务逻辑的东西就可以了。

 

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注服务器之家的更多内容!

原文链接:https://blog.csdn.net/weixin_44741023/article/details/120183703