SpringBoot快速入门-上

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 的构建系统创建

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

}

请求处理类

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

  • 自己创建的找不到

    //请求处理类
    @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或将其视为null true
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完成映射

@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完成映射

@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;
    }
    
    @Override
    public String toString() {
        return "user{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", addre='" + addre + '\'' +
                '}';
    }
}

数组集合参数

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

@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 注解完成日期

@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标识

@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获取参数路径.

@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结合使用。

相关推荐

  1. springboot快速入门

    2024-06-19 04:02:03       36 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-19 04:02:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-19 04:02:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-19 04:02:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-19 04:02:03       18 阅读

热门阅读

  1. [qt][报错】[Makefile:1293: moc_widget.cpp] Error 1

    2024-06-19 04:02:03       8 阅读
  2. 【Qt】xml文件节点读取

    2024-06-19 04:02:03       5 阅读
  3. 6、while循环 - 习题解析

    2024-06-19 04:02:03       5 阅读
  4. 华为OD机试 C++ - 跳格子1

    2024-06-19 04:02:03       9 阅读
  5. LeetCode 14. 最长公共前缀

    2024-06-19 04:02:03       6 阅读
  6. 部署YUM仓库及NFS共享服务

    2024-06-19 04:02:03       5 阅读
  7. LeetCode-day08-881. 救生艇

    2024-06-19 04:02:03       8 阅读