自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SpringBoot3基礎(chǔ)用法

開(kāi)發(fā) 開(kāi)發(fā)工具
最近在一個(gè)輕量級(jí)的服務(wù)中,嘗試了最新的技術(shù)和工具選型;即SpringBoot3,JDK17,IDEA2023,Navicat16,雖然新的技術(shù)和工具都更加強(qiáng)大和高效,但是適應(yīng)采坑的過(guò)程總是枯燥的。

一、背景

最近在一個(gè)輕量級(jí)的服務(wù)中,嘗試了最新的技術(shù)和工具選型;

即SpringBoot3,JDK17,IDEA2023,Navicat16,雖然新的技術(shù)和工具都更加強(qiáng)大和高效,但是適應(yīng)采坑的過(guò)程總是枯燥的;

【環(huán)境一覽】

圖片圖片

首先框架主體從SpringBoot2升級(jí)到SpringBoot3,Java基礎(chǔ)環(huán)境從JDK8升級(jí)到JDK17;

技術(shù)升級(jí)都到這步了,自然連帶著工具都升級(jí)到最新版本了,涉及到的其他組件,也會(huì)選擇與當(dāng)前框架適應(yīng)的版本;

至于為何使用JDK17,因?yàn)槭荢pringBoot3的最低依賴,也和官方的維護(hù)周期有關(guān);

圖片圖片

實(shí)際上如果JDK21已經(jīng)發(fā)布的話,個(gè)人更傾于這個(gè)版本,要是沒(méi)有合適的嘗試機(jī)會(huì),繼續(xù)使用JDK8也問(wèn)題不大;

另外開(kāi)發(fā)工具IDEA2021.2版本才開(kāi)始支持JDK17,所以如果版本過(guò)低的話也需要升級(jí),至于Navicat16純屬跟風(fēng)操作;

二、環(huán)境搭建

1、工程結(jié)構(gòu)

在工程結(jié)構(gòu)上沒(méi)有什么變化,通過(guò)maven組件構(gòu)建項(xiàng)目,對(duì)于入門案例來(lái)說(shuō),注意框架依賴,啟動(dòng)類,配置文件即可;

圖片圖片

2、框架依賴

在該工程中只是SpringBoot3框架的簡(jiǎn)單測(cè)試,所以只引入web依賴就足夠;

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>${spring-boot.version}</version>
    </dependency>
</dependencies>

至于Spring框架和其他組件的依賴,順著web依賴追溯即可,核心的依賴和版本都可以找到;

圖片圖片

3、環(huán)境配置

入門案例,在這里只簡(jiǎn)單的配置服務(wù)器和應(yīng)用名稱;

server:
  port: 8082                # 端口號(hào)
  tomcat:                   # Tomcat組件
    uri-encoding: UTF-8     # URI編碼

spring:
  application:
    name: boot-base

三、入門案例

1、測(cè)試接口

提供一個(gè)簡(jiǎn)單的Get請(qǐng)求接口,使用了部分JDK新版的語(yǔ)法,如果拋出異常會(huì)統(tǒng)一處理;

@RestController
public class BootBaseWeb {

    @GetMapping("/boot/base/{id}")
    public Map<String,String> getInfo (@PathVariable String id){
        if (id.isBlank() || "0".equals(id)){
            throw new RuntimeException("參數(shù)ID錯(cuò)誤");
        }
        var dataMap = new HashMap<String,String>();
        dataMap.put("id",id);
        dataMap.put("boot","base");
        return dataMap ;
    }
}

2、全局異常

基于注解RestControllerAdvice和ExceptionHandler統(tǒng)一異常處理;

@RestControllerAdvice
public class HandlerExe {

    @ExceptionHandler(value = Exception.class)
    public Map<String,String> handler02 (HttpServletRequest request, Exception e){
        var errorMap = new HashMap<String,String>() ;
        errorMap.put("code","500");
        errorMap.put("url",request.getRequestURL().toString());
        errorMap.put("msg",e.getMessage());
        return errorMap ;
    }
}

3、日志打印

3.1 日志配置

在application.yml文件中,簡(jiǎn)單的添加日志配置內(nèi)容,然后從日志文件或者控制臺(tái)輸出查看相關(guān)信息;

logging:
  level:
    root: info
  file:
    path: ./
    name: logs/${spring.application.name}.log
  pattern:
    console: "%d{yyyy-MM-dd HH:mm:ss} %contextName [%thread] %-5level %logger- %msg%n"
    file: "%d{yyyy-MM-dd HH:mm:ss} %contextName [%thread] %-5level %logger- %msg%n"
  logback:
    rolling-policy:
      max-history: 7
      max-file-size: 10MB
      total-size-cap: 50MB

3.2 日志打印

雖然采用的是logback組件,但是使用slf4j的API即可;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@RestController
public class BootLogWeb {

    private static final Logger LOGGER = LoggerFactory.getLogger(BootBaseWeb.class);

    @GetMapping("/boot/print/log")
    public String printLog (HttpServletRequest request){
        LOGGER.info("remote-host:{}",request.getRemoteHost());
        LOGGER.info("request-uri:{}",request.getRequestURI());
        return request.getServerName() ;
    }
}

四、打包運(yùn)行

打包代碼工程中的m1-01-boot-base子模塊,以及其相關(guān)的依賴;

mvn clean -pl m1-01-boot-base -am -Dmaven.test.skip=true package

運(yùn)行m1-01-boot-base.jar服務(wù),并指定相應(yīng)的端口號(hào)為8080,然后測(cè)試其中相關(guān)接口查看日志即可;

java -jar m1-01-boot-base.jar --server.port=8080

五、參考源碼

文檔倉(cāng)庫(kù):
https://gitee.com/cicadasmile/butte-java-note

源碼倉(cāng)庫(kù):
https://gitee.com/cicadasmile/butte-spring-parent

責(zé)任編輯:武曉燕 來(lái)源: 知了一笑
相關(guān)推薦

2023-08-08 08:23:08

Spring日志?線程池

2023-08-09 08:29:51

SpringWeb編程

2023-08-11 08:59:49

分庫(kù)分表數(shù)據(jù)數(shù)據(jù)庫(kù)

2024-10-08 08:26:43

2024-07-31 14:03:00

Spring定時(shí)任務(wù)管理

2023-06-19 08:05:17

RFCwebSpring

2024-09-11 09:15:06

2024-03-04 08:19:11

SpringURLHeader

2024-05-10 08:10:05

Spring虛擬線程JDK

2023-02-01 10:40:01

2024-01-31 08:26:44

2023-05-10 11:34:06

springboot日志服務(wù)器

2022-01-27 23:39:46

Java17版本Spring

2023-09-08 09:10:33

SpringBoot微服務(wù)架構(gòu)

2021-07-11 07:05:28

RedisSpringBoot用法

2021-05-26 06:22:34

SpringBootJPA后端開(kāi)發(fā)

2021-06-05 07:34:00

SpringBootMybatis用法

2021-12-28 09:03:28

Gotest語(yǔ)言

2025-04-16 10:03:40

開(kāi)發(fā)Spring應(yīng)用程序

2020-10-21 12:45:12

Redis數(shù)據(jù)結(jié)構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)