SpringBoot快速入门-上

embedded/2025/2/23 2:25:39/

Apache Tomcat

Apache Tomcat是一个开源的Servlet 或 web容器,它实现了Java Servlet、JavaServer Pages (JSP)、Java Unified Expression Language (JUEL) 和 Java WebSocket 规范。

使用

  • 官网下载

  • 安装:绿色版 , 直接解压

  • 卸载:直接删除目录

  • 改编码:

    # conf/logging.properties
    java.util.logging.ConsoleHandler.encoding = UTF 8
    #改为
    java.util.logging.ConsoleHandler.encoding = GBK

  • 改端口

    • <!-- conf/server.xml -->
      <Connector port:"8080"  ....> </Connector>

  • 运行: bin\startup.bat;

  • 将web网页,部署在 webapps 文件夹下

  • 关闭:

    • 直接 x 掉运行窗口:强制关闭

    • bin\shutdown.bat:正常关闭

    • Cltrl+ c :正常关闭

springBoot

  • 内嵌Tomcat服务器

  • 起步依赖(也称为“启动器依赖”或“Starters”)

    • 指:特殊的依赖抽象,旨在简化Maven或Gradle项目的依赖管理。起步依赖本质上是一组预定义的依赖项集合,它们通常包括了构建特定类型的Spring应用程序所需的核心库。

    • spring-boot-starter:基础起步依赖,包含Spring Boot的核心库。

    • spring-boot-starter-web:用于构建Web应用程序。

    • spring-boot-starter-data-jpa:用于添加JPA(Java Persistence API)支持。

    • spring-boot-starter-security:用于添加Spring Security支持。

Spring Boot 的主要特点和优势包括:

  1. 自动配置:Spring Boot 试图根据添加到项目中的 jar 依赖自动配置 Spring 应用程序。例如,如果类路径上有 Spring JDBC,它会自动配置一个 DataSource。

  2. 独立运行:Spring Boot 应用程序可以打包成一个独立的 JAR 包,包含所有的依赖项,从而可以轻松地运行和部署。这意味着不需要外部的应用服务器,应用程序可以通过运行 java -jar 命令启动。

  3. 内置的运行时选择:Spring Boot 包含了嵌入式的 Tomcat、Jetty 或 Undertow,开发者可以选择其中之一作为 Web 服务器。

  4. 生产就绪特性:提供了一系列监控和管理生产环境的特性,如指标、健康检查和外部化配置。

  5. 无代码生成和 XML 配置:不需要代码生成,也不需要 XML 配置文件,尽可能地利用约定和注解来配置应用程序。

  6. 简化依赖管理:通过提供 starter 依赖项,Spring Boot 简化了构建配置。例如,要开始一个 Spring Web MVC 应用程序,只需添加 spring-boot-starter-web 依赖。

  7. 微服务支持:Spring Boot 与 Spring Cloud 配合使用,可以方便地构建微服务架构的应用程序。

创建sprinBootWeb项目

不需要

解析pom.xml

不懂Maven可以看我之前的快速入门http://t.csdnimg.cn/B5jYA

<?xml version="1.0" encoding="UTF-8"?>
<!-- 这是XML文件的声明,指定了使用的版本和字符编码 --><project xmlns="http://maven.apache.org/POM/4.0.0"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <!-- 项目根元素,包含了项目的所有配置信息 --><modelVersion>4.0.0</modelVersion><!-- 指定了POM遵循的模型版本,这是Maven理解项目结构的方式 --><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.3.0</version><relativePath/> <!-- 这里通常用于相对查找父POM,但这里留空表示从仓库中获取 --></parent><!-- 指定了父POM,Spring Boot的父POM提供了许多默认配置,简化了项目配置 --><groupId>com.example</groupId><!-- 定义了项目组的ID,通常是公司或组织的域逆序,加上项目的路径 --><artifactId>SpringWeb5</artifactId><!-- 定义了项目的ID,用于唯一标识项目 --><version>0.0.1-SNAPSHOT</version><!-- 定义了项目的版本号,SNAPSHOT表示这是一个开发中的版本,不是正式发布的版本 --><name>SpringWeb5</name><!-- 定义了项目的名称,用于在IDE或构建工具中显示 --><description>SpringWeb5</description><!-- 定义了项目的描述,可以是项目的简短介绍 --><properties><java.version>17</java.version></properties><!-- 定义了项目属性,这里指定了Java的版本 --><dependencies><!-- 定义了项目依赖的库,Maven会自动下载并管理这些依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- 添加了Spring Boot Web Starter依赖,它包含了构建RESTful Web服务所需的Spring组件 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!-- 添加了Spring Boot Test Starter依赖,它包含了用于测试的Spring组件,scope指定了依赖仅在测试阶段有效 --></dependencies><build><plugins><!-- 定义了构建过程中使用的插件 --><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><!-- Spring Boot Maven插件,提供了创建可执行jar和war文件的功能,以及其他Spring Boot特定的Maven任务 --></plugins></build>
</project>

两个重要类

自己找找

启动类

  • javaBoot 的构建系统创建

java">//启动类
@SpringBootApplication
public class SpringWeb5Application {public static void main(String[] args) {SpringApplication.run(SpringWeb5Application.class, args);}}

请求处理类

  • 用户创建 :为类加上类注解(@RestController), 为每个方法加上注解(@RequestMapping("/test"))

  • 自己创建的找不到

    java">//请求处理类
    @RestController
    public class TestController {//请求处理方法@RequestMapping("/test")public String test(){return "Hello Spring Boot! old version!";}//带路径参数的请求方法@RequestMapping("/test/{id}")public String test(){return "Hello Spring Boot! old version!";}
    }

Javaboot@注解

不做详细解释

@RequestParam

属性描述默认值
value指定要绑定的请求参数的名字。通常省略此属性,直接使用注解时的参数名作为value的值。(无默认值)
name这是value属性的别名,用于指定请求参数的名称。(无默认值)
defaultValue当请求中未提供参数时,指定参数的默认值。""
required指定参数是否必须存在于请求中。如果设为false,并且请求中没有此参数,那么将使用defaultValue或将其视为nulltrue
type指定转换器的类型,用于将请求参数转换为目标类型。在Spring 5之后,这可以通过@Qualifier注解实现。(无默认值)

请求HttpServietRequest

工具Postman

默认推荐Apifox

一款强大的模拟网页请求的工具包括但不限于

  • HTTP请求: Postman允许你构建和发送各种类型的HTTP请求,包括GET, POST, PUT, DELETE等,并可以添加各种请求头(headers)、查询参数(query parameters)、请求体(request body)和认证信息(authentication)。

  • 响应查看: 可以查看和分析API的响应,包括状态码、响应头和响应体,甚至可以预览JSON或XML格式的数据。

  • 环境变量: 可以设置和管理环境变量,这有助于在不同的环境中(如开发、测试、生产)切换API配置。

  • 集合(Collections): 这个特性允许你组织相关的请求到集合中,便于管理和共享API测试流程。

  • 自动化测试: 支持编写测试脚本,自动运行测试用例,并生成详细的测试报告。

  • 监控与集成: 可以设置监控定期检查API的健康状况,并通过Webhooks与其他工具集成。

  • 文档生成: Postman可以自动生成API文档,帮助团队成员理解API的功能和用法。

  • 协作: 支持团队协作,可以分享集合、环境和文档,促进团队间的沟通和合作。

  • Postman API: 提供了自身的API,允许开发者通过代码来控制和扩展Postman的功能。

  • 桌面应用与浏览器插件: Postman不仅有桌面应用版本,也有作为Chrome和Firefox浏览器插件的形式。

(以下使用)工具Apifox

更强跟适合团队开发

  • 一体化平台

    • Apifox 将 API 文档、API 测试、API Mock 服务和 API 自动化测试等功能整合在一个平台上,这意味着你可以在一个地方完成所有与 API 相关的工作,而不需要在多个工具之间切换。

  • 文档管理

    • Apifox 的文档功能遵循 OpenAPI 3.0 规范,提供了高效的可视化文档管理,使得创建和维护 API 文档更加直观和方便。

  • 数据同步

    • 使用 Apifox,你只需要定义一次 API 文档,就可以在测试、调试、模拟和自动化测试中重复使用,避免了数据在多个系统间同步的问题。

  • 测试效率

    • Apifox 在测试方面提供了高效的功能,例如环境变量管理、前置/后置脚本、全局共享 Cookie/Session 等,这些功能与 Postman 类似但声称使用起来更高效。

  • 脚本兼容性与灵活性

    • Apifox 的自定义脚本支持多种编程语言,包括 JavaScript、Java、Python、PHP 等,这比仅支持 JavaScript 的 Postman 提供了更多的灵活性。

  • 导入导出

    • Apifox 支持多种格式的导入,包括 OpenAPI、yapi、RAP2 和 Postman,这使得从其他工具迁移数据变得更加容易。

简单参数

  • 方法形参名与请求参数,一 一对应,或者使用@requestParam完成映射

java">@RestController
public class TestController(){@RequestMapping("/test1")public String test1(String name,Integer age,@requestParam(addre = "addre") String address){System.out.println(name + ":" + age +"--" + address);return "ok";}
}

实体参数

  • 方法形参名与请求参数,一 一对应,或者使用@requestParam完成映射

java">@RestController
public class TestRestContorller{@RequstMaping("/test1")public String test1(user val){System.out.println(val);}
}//其他文件
public class user{String name;Integer age;String  addre;//web的请求参数名和实体类属性无关,只和set/get的有关void setTest(String ab){this.name =  ab;//那么 web 请求时带的参数必须是 Test=abc 或 test=abc;}@Overridepublic String toString() {return "user{" +"name='" + name + '\'' +", age=" + age +", addre='" + addre + '\'' +'}';}
}

数组集合参数

  • 请求参数名和数组名相同,且参数名重复多个,定义数组或 @RequestParam + 其他

java">@RestController
public class TestRestContorller{@RequestMapping("/test3")public String test3(String []form){System.out.println(form[0] + "--" + form[1]);return "ok_test3";}@RequestMapping("/test4")public String test_3(@RequestParam List<String> form){System.out.println(form.get(0) + "--" + form.get(1));return "ok_test_3";}}

日期参数

  • 使用 @DateTimeFormat 注解完成日期

java">@RestController
public class  TestController{@RequestMapping("/test5")public String test5(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")LocalDateTime time){System.out.println(time);return "ok_test5";}
}
// HH 是24小时制 hh是12小时制

Json参数

  • JSON数据键名与形参对象属性名(其实只要set相同就可以了)相同,定义POJO(Plain Old Java Object)普通的Java对象需要使用@RequestBody标识

java">@RestController
public class TestController{@RequestMapping("/test6")public String test6(@RequestBody _User val) {System.out.println(val);return "ok_test6";}
}//其他文件
class User{String name;String age;Addres addre;//所有set/get方法......
}
class Addres{String province;String city;//所有set/get方法......
}

路径参数

  • 通过请求URL直接传输参数使用{...}来标识路径参数,需要**@PathVariable获取参数路径.

java">@RestController
public class TestController{@RequestMapping("/test7/{id}/{name}")public String test7(@PathVariable Integer id,@PathVariable String name){System.out.println("id =" + id  + " name =" + name);return "ok_test7";}}

总结

参数类型描述绑定方式适用场景补充说明
简单参数基本数据类型参数,如int、String等。通过方法形参自动绑定,或使用@RequestParam注解手动映射。适用于单个基本数据类型的参数接收。形参变量名与请求参数名一致时自动绑定。
实体参数POJO对象参数,请求参数名与实体对象属性名一致。自动封装,通过属性名绑定。适用于接收对象类型的请求参数。支持嵌套对象和数组。
数组集合参数数组或集合类型参数,如List、Set等。请求参数名与数组或集合名一致,使用@RequestParam注解绑定。适用于接收数组或集合类型的请求参数。可以接收多个相同类型的参数值。
日期参数日期类型的参数,如java.util.Date。使用@DateTimeFormat注解格式化日期参数。适用于接收日期类型的请求参数。支持自定义日期格式。
JSON参数请求体为JSON格式的参数。使用@RequestBody注解接收JSON格式的请求体。适用于接收复杂JSON对象或数组。需要在HTTP请求的Content-Type头部设置为application/json。
路径参数URI模板变量,如RESTful API中的资源标识符。使用@PathVariable注解绑定URI模板变量。适用于RESTful API中,将URL的一部分映射到方法参数。通常与@RequestBody或@RequestParam结合使用。

http://www.ppmy.cn/embedded/50387.html

相关文章

Spring Boot定时任务编程指南:如何创建和配置周期性任务

&#x1f341; 作者&#xff1a;知识浅谈&#xff0c;CSDN签约讲师&#xff0c;CSDN博客专家&#xff0c;华为云云享专家&#xff0c;阿里云专家博主 &#x1f4cc; 擅长领域&#xff1a;全栈工程师、爬虫、ACM算法 &#x1f525; 微信&#xff1a;zsqtcyw 联系我领取学习资料 …

Linux操作系统学习:day03

内容来自&#xff1a;Linux介绍 视频推荐&#xff1a;[Linux基础入门教程-linux命令-vim-gcc/g -动态库/静态库 -makefile-gdb调试]( 目录 day0317、创建删除目录创建目录删除目录 18、文件的拷贝19、mv 命令20、查看文件内容的相关命令21、给文件创建软连接或硬链接 day03 …

探索C嘎嘎的奇妙世界:第十四关---STL(string的模拟实现)

1. string类的模拟实现 1.1 经典的string类问题 上一关已经对string类进行了简单的介绍&#xff0c;大家只要能够正常使用即可。在面试中&#xff0c;面试官总喜欢让学生自己来模拟实现string类&#xff0c;最主要是实现string类的构造、拷贝构造、赋值运算符重载以及析构函数…

Node.js中基于node-schedule实现定时任务之详解

文章目录 一、定时任务二、node-schedule、1、安装2、引入3、基于Cron表达式的规则4、基于Date的规则5、基于RecurrenceRule的规则6、API7、状态监听 一、定时任务 实际工作中&#xff0c;可能会遇到定时清除某个文件夹内容&#xff0c;定时发送消息或发送邮件给指定用户&…

性能测试-监控工具:grafana-普罗米修斯

性能测试时&#xff0c;需要关注服务器指标&#xff0c;一般应用服务器关注CPU和内存&#xff0c;数据库服务器关注CPU、内存和I/O&#xff1b; 监控工具&#xff1a;grafana-普罗米修斯 Quick CPU / Mem / Disk 关注实时指标&#xff1a; CPU Busy&#xff1a;收集所有 CPU…

PostgreSQL Schema管理基础

Postgresql schema是什么、为什么它们很重要以及如何使用schema(模式)使您的数据库实现更加健壮和可维护&#xff1f;本文将介绍 Postgresql 中schema的基础知识&#xff0c;并通过一些基本示例向您展示如何创建它们。未来的文章将深入探讨如何保护和使用实际应用程序schema的示…

Docker镜像构建:Ubuntu18.04+python3.10

1、编写 Dockerfile # 使用Ubuntu 18.04作为基础镜像 FROM ubuntu:18.04RUN apt-get update && apt-get install -y \build-essential \curl \zlib1g-dev \libssl-dev \&& rm -rf /var/lib/apt/lists/*ENV PYTHON_VERSION3.10.8RUN curl -O https://www.pytho…

P450Rdb: CYP450数据库--地表最强系列--文献精读24

P450Rdb: A manually curated database of reactions catalyzed by cytochrome P450 enzymes P450Rdb: 一个人工整理的细胞色素P450酶催化反应数据库 http://www.cellknowledge.com.cn/p450rdb/ 还有一篇类似CYP450综述-20年-地表最强系列-文献精读-4 要点&#xff1a; P450…