当前位置:主页 > 软件编程 > JAVA代码 >

Java SpringBoot开发小技巧详解

时间:2023-02-21 13:44:39 | 栏目:JAVA代码 | 点击:

一、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,让他生效)

在这里插入图片描述

使用这个插件后,我们以后开发的时候的那些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方法也没问题。

在这里插入图片描述

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

在这里插入图片描述

控制台输出也没问题。

在这里插入图片描述

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端口号就不行了。开发网页啥的时候也是一样,改完代码,直接编译,然后回去网站刷新一下即可。

在这里插入图片描述

1.3 Spring Initializr

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

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

在这里插入图片描述

在这里插入图片描述

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

在这里插入图片描述

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

总结

您可能感兴趣的文章:

相关文章