当前位置: 首页 > news >正文

SpringBoot3基础用法

技术和工具「!喜新厌旧」

一、背景

最近在一个轻量级的服务中,尝试了最新的技术和工具选型;

SpringBoot3JDK17IDEA2023Navicat16,虽然新的技术和工具都更加强大和高效,但是适应采坑的过程总是枯燥的;

【环境一览】

首先框架主体从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、全局异常

基于注解RestControllerAdviceExceptionHandler统一异常处理;

@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: infofile:path: ./name: logs/${spring.application.name}.logpattern: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: 7max-file-size: 10MBtotal-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
http://www.lryc.cn/news/114798.html

相关文章:

  • 6、移除链表元素
  • 大厂容器云实践之路(一)
  • 《合成孔径雷达成像算法与实现》Figure3.1
  • 代码随想录算法训练营day60
  • Modbus TCP转Profibus DP网关modbus tcp报文解析
  • 对 Promise 的理解
  • Vuex:Vue.js应用程序的状态管理模式
  • Unity之ShaderGraph 节点介绍 Utility节点
  • springboot()—— swagger
  • Java课题笔记~ 关联映射
  • 一零六七、JVM梳理
  • 【CSS】网格布局(简单布局、网格合并、网格嵌套)
  • 06 Ubuntu22.04上的miniconda3安装、深度学习常用环境配置
  • 【CSS3】CSS3 动画 ② ( 动画序列 | 使用 from 和 to 定义动画序列 | 定义多个动画节点 | 代码示例 )
  • 最优化:建模、算法与理论
  • 拿捏--->打印菱形
  • 【SpringBoot笔记】定时任务(cron)
  • Redis单机,主从,哨兵,集群四大模式
  • 2023年8月份华为H12-811更新了
  • [K8S:命令执行:权限异常:解决篇]:通过更新kubeconfig配置相关信息
  • 帆软设计器报表加载不出折线图的原因
  • [QCA6174]sdx12平台WiFi QCA6174在驱动加载的时候增加模块参数方法
  • Ajax-AJAX请求的不同发送方式
  • 简易图书管理系统(面向对象思想)
  • C++ 函数模板与类模板
  • Tailwind CSS:简洁高效的工具,提升前端开发体验
  • NR CSI(六) CSI reporting using PUCCH
  • 论文阅读---《Unsupervised Transformer-Based Anomaly Detection in ECG Signals》
  • 5G上行干扰规避的参数策略
  • CTF流量题解tcp1