成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SpringBoot3基礎用法

開發 開發工具
最近在一個輕量級的服務中,嘗試了最新的技術和工具選型;即SpringBoot3,JDK17,IDEA2023,Navicat16,雖然新的技術和工具都更加強大和高效,但是適應采坑的過程總是枯燥的。

一、背景

最近在一個輕量級的服務中,嘗試了最新的技術和工具選型;

即SpringBoot3,JDK17,IDEA2023,Navicat16,雖然新的技術和工具都更加強大和高效,但是適應采坑的過程總是枯燥的;

【環境一覽】

圖片圖片

首先框架主體從SpringBoot2升級到SpringBoot3,Java基礎環境從JDK8升級到JDK17;

技術升級都到這步了,自然連帶著工具都升級到最新版本了,涉及到的其他組件,也會選擇與當前框架適應的版本;

至于為何使用JDK17,因為是SpringBoot3的最低依賴,也和官方的維護周期有關;

圖片圖片

實際上如果JDK21已經發布的話,個人更傾于這個版本,要是沒有合適的嘗試機會,繼續使用JDK8也問題不大;

另外開發工具IDEA2021.2版本才開始支持JDK17,所以如果版本過低的話也需要升級,至于Navicat16純屬跟風操作;

二、環境搭建

1、工程結構

在工程結構上沒有什么變化,通過maven組件構建項目,對于入門案例來說,注意框架依賴,啟動類,配置文件即可;

圖片圖片

2、框架依賴

在該工程中只是SpringBoot3框架的簡單測試,所以只引入web依賴就足夠;

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

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

圖片圖片

3、環境配置

入門案例,在這里只簡單的配置服務器和應用名稱;

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

spring:
  application:
    name: boot-base

三、入門案例

1、測試接口

提供一個簡單的Get請求接口,使用了部分JDK新版的語法,如果拋出異常會統一處理;

@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("參數ID錯誤");
        }
        var dataMap = new HashMap<String,String>();
        dataMap.put("id",id);
        dataMap.put("boot","base");
        return dataMap ;
    }
}

2、全局異常

基于注解RestControllerAdvice和ExceptionHandler統一異常處理;

@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文件中,簡單的添加日志配置內容,然后從日志文件或者控制臺輸出查看相關信息;

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() ;
    }
}

四、打包運行

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

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

運行m1-01-boot-base.jar服務,并指定相應的端口號為8080,然后測試其中相關接口查看日志即可;

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

五、參考源碼

文檔倉庫:
https://gitee.com/cicadasmile/butte-java-note

源碼倉庫:
https://gitee.com/cicadasmile/butte-spring-parent

責任編輯:武曉燕 來源: 知了一笑
相關推薦

2023-08-08 08:23:08

Spring日志?線程池

2023-08-09 08:29:51

SpringWeb編程

2024-10-08 08:26:43

2023-08-11 08:59:49

分庫分表數據數據庫

2023-06-19 08:05:17

RFCwebSpring

2024-09-11 09:15:06

2024-07-31 14:03:00

Spring定時任務管理

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

2022-01-27 23:39:46

Java17版本Spring

2023-09-08 09:10:33

SpringBoot微服務架構

2023-05-10 11:34:06

springboot日志服務器

2025-04-16 10:03:40

開發Spring應用程序

2021-07-11 07:05:28

RedisSpringBoot用法

2021-05-26 06:22:34

SpringBootJPA后端開發

2021-06-05 07:34:00

SpringBootMybatis用法

2025-05-06 03:10:00

KEDASpringRocketMQ

2021-12-28 09:03:28

Gotest語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91精品国产综合久久久久久首页 | 毛片在线免费 | 亚洲成人国产综合 | 国产在线一区二区三区 | 男女视频在线免费观看 | 亚洲狠狠| 成人影音| 精品一区二区三区四区外站 | 国产精品一区二区av | 亚洲最大福利网 | 亚洲视频中文字幕 | 精品综合在线 | 99riav国产一区二区三区 | 91黄在线观看 | 国产偷录叫床高潮录音 | 欧美成ee人免费视频 | 国产视频第一页 | 久久久www成人免费精品 | 欧美激情一区二区三级高清视频 | 久久看看 | 精品国产一区二区在线 | a级性视频 | 一区二区三区播放 | 妖精视频一区二区三区 | 精品不卡| 亚洲三级在线观看 | 久久精品91 | 国产精品成人国产乱一区 | 日韩精品久久久久久 | 亚洲美女一区 | 91精品午夜窝窝看片 | 欧美精品一区在线 | 国产一区二区精品在线观看 | av片在线观看 | 成人精品在线观看 | 亚洲欧美综合精品另类天天更新 | 岛国av免费在线观看 | 九九热精 | 亚洲 中文 欧美 日韩 在线观看 | 日本欧美在线观看视频 | 婷婷亚洲综合 |