当前位置:首页 > 科技  > 软件

SpringBoot3基础用法

来源: 责编: 时间:2023-08-09 23:03:25 224观看
导读一、背景最近在一个轻量级的服务中,尝试了最新的技术和工具选型;即SpringBoot3,JDK17,IDEA2023,Navicat16,虽然新的技术和工具都更加强大和高效,但是适应采坑的过程总是枯燥的;【环境一览】图片首先框架主体从SpringBoot2升级

一、背景

最近在一个轻量级的服务中,尝试了最新的技术和工具选型;cM528资讯网——每日最新资讯28at.com

即SpringBoot3,JDK17,IDEA2023,Navicat16,虽然新的技术和工具都更加强大和高效,但是适应采坑的过程总是枯燥的;cM528资讯网——每日最新资讯28at.com

【环境一览】cM528资讯网——每日最新资讯28at.com

图片图片cM528资讯网——每日最新资讯28at.com

首先框架主体从SpringBoot2升级到SpringBoot3,Java基础环境从JDK8升级到JDK17;cM528资讯网——每日最新资讯28at.com

技术升级都到这步了,自然连带着工具都升级到最新版本了,涉及到的其他组件,也会选择与当前框架适应的版本;cM528资讯网——每日最新资讯28at.com

至于为何使用JDK17,因为是SpringBoot3的最低依赖,也和官方的维护周期有关;cM528资讯网——每日最新资讯28at.com

图片图片cM528资讯网——每日最新资讯28at.com

实际上如果JDK21已经发布的话,个人更倾于这个版本,要是没有合适的尝试机会,继续使用JDK8也问题不大;cM528资讯网——每日最新资讯28at.com

另外开发工具IDEA2021.2版本才开始支持JDK17,所以如果版本过低的话也需要升级,至于Navicat16纯属跟风操作;cM528资讯网——每日最新资讯28at.com

二、环境搭建

1、工程结构

在工程结构上没有什么变化,通过maven组件构建项目,对于入门案例来说,注意框架依赖,启动类,配置文件即可;cM528资讯网——每日最新资讯28at.com

图片图片cM528资讯网——每日最新资讯28at.com

2、框架依赖

在该工程中只是SpringBoot3框架的简单测试,所以只引入web依赖就足够;cM528资讯网——每日最新资讯28at.com

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

至于Spring框架和其他组件的依赖,顺着web依赖追溯即可,核心的依赖和版本都可以找到;cM528资讯网——每日最新资讯28at.com

图片图片cM528资讯网——每日最新资讯28at.com

3、环境配置

入门案例,在这里只简单的配置服务器和应用名称;cM528资讯网——每日最新资讯28at.com

server:  port: 8082                # 端口号  tomcat:                   # Tomcat组件    uri-encoding: UTF-8     # URI编码spring:  application:    name: boot-base

三、入门案例

1、测试接口

提供一个简单的Get请求接口,使用了部分JDK新版的语法,如果抛出异常会统一处理;cM528资讯网——每日最新资讯28at.com

@RestControllerpublic 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统一异常处理;cM528资讯网——每日最新资讯28at.com

@RestControllerAdvicepublic 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文件中,简单的添加日志配置内容,然后从日志文件或者控制台输出查看相关信息;cM528资讯网——每日最新资讯28at.com

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即可;cM528资讯网——每日最新资讯28at.com

import org.slf4j.Logger;import org.slf4j.LoggerFactory;@RestControllerpublic 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子模块,以及其相关的依赖;cM528资讯网——每日最新资讯28at.com

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

运行m1-01-boot-base.jar服务,并指定相应的端口号为8080,然后测试其中相关接口查看日志即可;cM528资讯网——每日最新资讯28at.com

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

五、参考源码

文档仓库:https://gitee.com/cicadasmile/butte-java-note源码仓库:https://gitee.com/cicadasmile/butte-spring-parent

cM528资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-5180-0.htmlSpringBoot3基础用法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 五分钟帮您理解Linux网络核心知识点——Socket和Epoll

下一篇: 国产130亿参数大模型免费商用!性能超Llama2-13B,支持8k上下文,哈工大已用上

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 服务存储设计模式:Cache-Aside模式

    服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 一年经验在二线城市面试后端的经验分享

    一年经验在二线城市面试后端的经验分享

    忠告这篇文章只适合2年内工作经验、甚至没有工作经验的朋友阅读。如果你是2年以上工作经验,请果断划走,对你没啥帮助~主人公这篇文章内容来自 「升职加薪」星球星友 的投稿,坐
  • 大厂卷向扁平化

    大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • 2299元起!iQOO Pad明晚首销:性能最强天玑平板

    2299元起!iQOO Pad明晚首销:性能最强天玑平板

    5月23日,iQOO如期举行了新品发布会,除了首发安卓最强旗舰处理器的iQOO Neo8系列新机外,还在发布会上推出了旗下首款平板电脑——iQOO Pad,其最大的卖点
  • iQOO Neo8系列今日官宣:首发天玑9200+ 全球安卓最强芯!

    iQOO Neo8系列今日官宣:首发天玑9200+ 全球安卓最强芯!

    在昨日举行的的联发科新一代旗舰芯片天玑9200+的发布会上,iQOO官方也正式宣布,全新的iQOO Neo8系列新品将全球首发搭载这款当前性能最强大的移动平台
  • iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 朋友圈可以修改可见范围了 苹果用户可率先体验

    朋友圈可以修改可见范围了 苹果用户可率先体验

    近日,iOS用户迎来微信8.0.27正式版更新,除了可更换二维码背景外,还新增了多项实用功能。在新版微信中,朋友圈终于可以修改可见范围,简单来说就是已发布的朋友圈
  • 联想的ThinkBook Plus下一版曝光,键盘旁边塞个平板

    联想的ThinkBook Plus下一版曝光,键盘旁边塞个平板

    ThinkBook Plus 是联想的一个特殊笔记本类别,它在封面放入了一块墨水屏,也给人留下了较为深刻的印象。据有人爆料,联想的下一款 ThinkBook Plus 可能更特殊,它
Top
Baidu
map