成人免费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編程

2023-08-11 08:59:49

分庫分表數據數據庫

2024-10-08 08:26:43

2024-07-31 14:03:00

Spring定時任務管理

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-09-08 09:10:33

SpringBoot微服務架構

2023-05-10 11:34:06

springboot日志服務器

2022-01-27 23:39:46

Java17版本Spring

2025-04-16 10:03:40

開發Spring應用程序

2021-05-26 06:22:34

SpringBootJPA后端開發

2021-06-05 07:34:00

SpringBootMybatis用法

2021-07-11 07:05:28

RedisSpringBoot用法

2021-12-28 09:03:28

Gotest語言

2025-05-06 03:10:00

KEDASpringRocketMQ
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91久久久久久久久久久久久 | 久久成人国产精品 | 日韩电影免费观看中文字幕 | 欧美日韩国产精品一区二区 | 久久精品国产一区 | 久久99精品国产 | 成人3d动漫一区二区三区91 | 久久久精品一区 | 亚洲综合精品 | 中文字幕欧美在线观看 | 精品伊人久久 | 精品九九 | 国产精品久久久久久久久免费相片 | 亚洲精品99999| 国产yw851.c免费观看网站 | 亚洲国产成人精品女人久久久 | 国产成人精品免费视频 | 欧产日产国产精品视频 | 中文字幕免费视频 | 九九久久精品 | 国产精品久久久久久久久久尿 | 观看av| 亚洲另类自拍 | 久草久 | 国产九九九九 | 午夜一区 | 国产成人精品一区二区三区网站观看 | 亚洲性免费 | 91在线观看网址 | 男女视频在线观看网站 | 99久久久99久久国产片鸭王 | 97久久精品午夜一区二区 | 欧美在线视频免费 | 黄色免费三级 | 亚洲日韩中文字幕一区 | 国内精品视频在线 | 美日韩免费视频 | 国产精品一区二区在线观看 | 亚洲福利在线观看 | 免费国产一区二区 | 精品国产视频 |