SpringBoot六种API请求参数读取方式

SpringBoot六种API请求参数读取方式

同步请求和异步请求

  • 同步: 指单线程依次做几件事
  • 异步: 指多线程同时做几件事

同步请求: 指客户端浏览器只有一个主线程, 此线程负责页面的渲染和发出请求等操作, 如果此主线程发出请求的话则停止渲染而且会清空页面显示的内容 直到服务器响应了数据后才能再次显示, 由于主线程清空了原有显示的内容所以只能实现页面的整体刷新(整体改变)

异步请求: 指客户端的主线程只负责页面渲染相关操作,发请求的事由新的子线程操作, 这样子线程发出请求时页面不需要清空,而且可以将查询回来的数据展示在原有页面基础之上, 这样实现的效果就叫做页面的局部刷新

客户端发出请求的几种方式

  • 通过浏览器的地址栏中发出请求 同步请求

  • 通过html页面中的超链接发出请求 同步请求

  • 通过html页面中的form表单发出请求 同步请求

  • 通过前端框架发出请求 异步请求

HTTP请求

  • 请求地址
  • 请求方法
  • 状态码
  • 同源策略
  • 请求头
  • 响应头

HTTP状态码


| 序号 | 方法   | 描述                                                         |
| ---- | ------ | ------------------------------------------------------------ |
| 1    | GET    | 用于请求服务器发送某个资源。GET请求不应该对服务器上的资源做出任何更改,并且应该是幂等的(即多次重复的请求应该产生相同的结果)。例如,当你在浏览器中输入URL地址时,浏览器会发送一个GET请求来获取该URL对应的网页。 |
| 2    | HEAD   | 类似于GET请求,但服务器不返回请求的资源主体,只返回响应头。HEAD请求通常用于获取资源的元信息,如资源的大小、类型等,而不需要获取资源的实际内容。 |
| 3    | POST   | 用于向服务器提交数据,通常用于提交表单或上传文件。POST请求可能会导致服务器上的状态更改,并且不一定是幂等的。例如,在提交注册表单时,浏览器通常会发送一个POST请求,将用户提供的信息发送到服务器进行处理。 |
| 4    | PUT    | 用于向服务器上传资源,通常用于更新已存在的资源或创建新的资源。PUT请求应该是幂等的,即多次执行相同的PUT请求应该产生相同的结果。 |
| 5    | DELETE | 用于请求服务器删除指定的资源。DELETE请求应该是幂等的,即多次执行相同的DELETE请求应该产生相同的结果。 |
| 6    | CONNECT | 用于建立到服务器上指定端口的隧道,通常用于代理服务器。 |
| 7    | OPTIONS | 用于请求服务器返回支持的HTTP方法和其他选项。例如,客户端可以发送OPTIONS请求来确定服务器支持哪些CORS(跨域资源共享)策略。 |
| 8    | TRACE  | 回显服务器收到的请求,主要用于测试或诊断。               |
| 9    | PATCH  | 用于在请求-响应链上的每个节点获取传输路径。PATCH请求通常用于调试和测试,以查看请求在经过各种代理服务器和中间件时如何被修改。 |

HTTP响应头信息


| 响应头信息(英文) | 响应头信息(中文) | 描述                                                                 |
|-------------------|--------------------|----------------------------------------------------------------------|
| Date              | 日期               | 响应生成的日期和时间。例如:Wed, 18 Apr 2024 12:00:00 GMT          |
| Server            | 服务器             | 服务器软件的名称和版本。例如:Apache/2.4.1 (Unix)                |
| Content-Type      | 内容类型           | 响应体的媒体类型(MIME类型),如text/html; charset=UTF-8, application/json等。|
| Content-Length    | 内容长度           | 响应体的大小,单位是字节。例如:3145                             |
| Content-Encoding  | 内容编码           | 响应体的压缩编码,如 gzip, deflate等。                         |
| Content-Language  | 内容语言           | 响应体的语言。例如:zh-CN                                        |
| Content-Location  | 内容位置           | 响应体的 URI。例如:/index.html                                 |
| Content-Range     | 内容范围           | 响应体的字节范围,用于分块传输。例如:bytes 0-999/8000          |
| Cache-Control     | 缓存控制           | 控制响应的缓存行为, 如 no-cache 表示必须重新请求。            |
| Connection        | 连接               | 管理连接的选项,如keep-alive或close,keep-alive 表示连接不会在传输后关闭。|
| Set-Cookie        | 设置 Cookie        | 设置客户端的 cookie。例如:sessionId=abc123; Path=/; Secure      |
| Expires           | 过期时间           | 响应体的过期日期和时间。例如:Thu, 18 Apr 2024 12:00:00 GMT    |
| Last-Modified     | 最后修改时间       | 资源最后被修改的日期和时间。例如:Wed, 18 Apr 2024 11:00:00 GMT|
| ETag              | 实体标签           | 资源的特定版本的标识符。例如:"33a64df551425fcc55e6"           |
| Location          | 位置               | 用于重定向的 URI。例如:/newresource                            |
| Pragma            | 实现特定的指令     | 包含实现特定的指令,如 no-cache。                             |
| WWW-Authenticate  | 认证信息           | 认证信息,通常用于HTTP认证。例如:Basic realm="Access to the site" |
| Accept-Ranges     | 接受范围           | 指定可接受的请求范围类型。例如:bytes                        |
| Age               | 经过时间           | 响应生成后经过的秒数,从原始服务器生成到代理服务器。例如:24   |
| Allow             | 允许方法           | 列出资源允许的 HTTP 方法 。例如:GET, POST,HEAD等           |
| Vary              | 变化               | 告诉下游代理如何使用响应头信息来确定响应是否可以从缓存中获取。例如:Accept |
| Strict-Transport-Security | 严格传输安全 | 指示浏览器仅通过 HTTPS 与服务器通信。例如:max-age=31536000; includeSubDomains |
| X-Frame-Options   | 框架选项           | 控制页面是否允许在框架中显示,防止点击劫持攻击。例如:SAMEORIGIN |
| X-Content-Type-Options | 内容类型选项 | 指示浏览器不要尝试猜测资源的 MIME 类型。例如:nosniff      |
| X-XSS-Protection   | XSS保护            | 控制浏览器的 XSS 过滤和阻断。例如:1; mode=block           |
| Public-Key-Pins   | 公钥固定           | HTTP 头信息,用于HTTP公共密钥固定(HPKP),一种安全机制,用于防止中间人攻击。例如:pin-sha256="base64+primarykey"; pin-sha256="base64+backupkey"; max-age=expireTime |

Get请求和Post请求

从字面理解:Get是跟服务器要数据, Post是给服务器传数据

  • Get: 请求参数写在请求地址的后面(可见),请求参数有大小限制只能穿几k的数据(不能处理文件上传) 应用场景: 查询请求一般都会使用get, 删除也会使用get请求

  • Post:请求参数放在请求体里面(不可见),参数没有大小限制 应用场景: 文件上传, 带有敏感信息的请求(比如注册登录时有密码)

🌐 URL 简介

URL 是互联网上用于检索任何资源的机制,代表统一资源定位符(Uniform Resource Locator)。它就像一个给定资源在网络上的独特地址,理论上任何资源都可以通过 URL 进行访问。

💻 URL 的组成

一个完整的 URL 通常由以下几个部分组成:协议、域名、路径、查询参数和片段标识符。例如,在 URL https://www.example.com/path/to/resource?query=string#fragment中,https 是协议,www.example.com 是域名,/path/to/resource 是路径,query=string 是查询参数,#fragment 是片段标识符.

🌍 URL 的作用 URL

在互联网上扮演着至关重要的角色,它使我们能够访问和共享各种资源,例如网页、图片、视频、文档等。通过 URL,我们可以轻松地找到所需的信息,并与他人进行交流。

[参考地址](https://tangjiusheng.com/web/qdkf/598.html)
(https://www.bookstack.cn/read/html-tutorial/spilt.4.docs-url.md)

1.@RequestParam

  • 作用:取URL中的查询参数,@RequestParam:将请求参数绑定到你控制器的方法参数上(是springmvc中接收普通参数的注解)
  • 使用场景:当需要从GET或POST请求的URL中读取参数时使用。
语法:@RequestParam(value=”参数名”,required=true/false,defaultValue=””)
 
value:参数名
 
required:是否包含该参数,默认为true,表示该请求路径中必须包含该参数,如果不包含就报错。
 
defaultValue:默认参数值,如果设置了该值,required=true将失效,自动为false,如果没有传该参数,就使用默认值

步骤:
1、创建web工程、引入依赖
2、配置SpringMvc入口文件 --DispatcherServlet--为总调度、web.xml里配置
3、创建Springmvc.xml文件--理解为:适配器(这里不需要自已指定适配、springmvc会自动指定)--视图解析器
4、创建 业务处理器 Controller5、测试

https://blog.csdn.net/sswqzx/article/details/84195043

1/2/3上述步骤参考此博文

  • 目录结构

  • 基本使用
package com.ncist.controller;


import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

/**
 * 功能:
 * 作者:兮和
 * 时间: 9:55
 */
@RestController
public class WebController {

    @GetMapping("/search")
    public String searchUser(@RequestParam(value = "keyword", required = false) String keyword, Model model) {
        // 如果 keyword 参数存在,则打印它;否则,使用默认值
        String message = (keyword != null) ? "搜索关键词: " + keyword : "没有提供搜索关键词";
        System.out.println(message);
        // 将消息添加到模型中
        model.addAttribute("msg", message);
        return keyword;
    }
}

apifox测试结果

控制台打印测试结果

终端控制台打印结果

  • 指定默认值
@GetMapping("/items")
public String listItems(@RequestParam(value = "category", defaultValue = "all") String category) {
    // 如果请求中没有提供 category 参数,将使用默认值 "all"
    System.out.println("列出类别为 " + category + " 的项目");
    return "items";
}
http://localhost:9090/items?category=books

apifox测试结果

  • 允许为空
@PostMapping("/register")
public String registerUser(@RequestParam(value = "age", required = false) Integer age) {
    if (age != null) {
        System.out.println("注册用户年龄: " + age);
    } else {
        System.out.println("年龄未提供");
    }
    return "registration-success";
}
  • 请求参数的多个值
    @GetMapping("/book")
    public String getBookDetails(@RequestParam("authors") List<String> authors) {
        // authors 参数可以接收多个值
        System.out.println("书籍作者: " + authors);
        return "book-details";
    }
  • 请求参数的条件处理
@GetMapping("/feature")
public String toggleFeature(@RequestParam(value = "enable", required = false) Boolean enable) {
    if (enable != null && enable) {
        System.out.println("功能已启用");
    } else {
        System.out.println("功能未启用或未指定");
    }
    return "feature-status";
}

上述数据示例结果和上文一样,使用apifox进行项目测试,你会发现上述数据的变化情况

2.@PathVariable

  • 作用:从URL的路径中提取变量
    基本使用:
    使用 @PathVariable 可以捕获URL模板中的变量。例如,/users/{id} 路径中的 {id} 是一个路径变量,可以通过 @PathVariable(“id”) 来获取。

类型转换:
Spring MVC 会尝试将路径变量的字符串值转换为方法参数的类型。如果转换失败,会抛出 TypeMismatchException。

正则表达式限制:
可以在 @PathVariable 的 value 属性中使用正则表达式来限制变量的格式,如 @GetMapping(“/users/{id:\d+}”)。

可选参数:
通过在路径变量名称后添加 ? 或设置 required = false 属性,可以将路径变量设置为可选。

默认值:
使用 defaultValue 属性为路径变量提供默认值。

与 @RequestParam 同时使用:
可以在同一个方法中同时使用 @PathVariable 和 @RequestParam 来获取路径变量和查询参数。

   @PostMapping(value = "/item/{id}/{method}")
    public String getForm(@PathVariable("id") String itemId ,  
        @PathVariable("method") String methodCall , Model model){

     if(methodCall.equals("create")){
            //logic
      }
     if(methodCall.equals("update")){
            //logic
      }

      return "path to your form";
    }

参考地址:https://blog.csdn.net/weixin_45393094/article/details/108814901

3.@MatrixVariable

  • 作用:用于从URL的矩阵参数中读取值
@RequestMapping(value="{path}/simple", method=RequestMethod.GET)
public @ResponseBody String withMatrixVariable(@PathVariable String path, @MatrixVariable String foo) {
    return "Obtained matrix variable 'foo=" + foo + "' from path segment '" + path + "'";
}

4.@RequestBody

  • 作用:读取HTTP请求的body部分,通常用于接收JSON或XML格式的数据。
    http://www.itsoku.com/article/216
@PostMapping("/users")
public ResponseEntity<?> addUser(@RequestBody User user) {
    // 处理用户对象
    return ResponseEntity.ok().body(user);
}

5.@RequestHeader

  • 作用:@RequestHeader:用于读取HTTP请求的header部分。
@GetMapping("/user-agent")
public ResponseEntity<String> getUserAgent(@RequestHeader(value = "User-Agent", required = false, defaultValue = "Unknown") String userAgent) {
    return ResponseEntity.ok("User Agent: " + userAgent);
}

6.@CookieValue

  • 作用:用于读取HTTP请求中的cookie值。
@GetMapping("/cookie")
public String getCookieValue(@CookieValue(value = "sessionId", defaultValue = "noSession") String sessionId) {
    return "Session ID: " + sessionId;
}

补充三种:

  • 直接把请求参数写在方法的形参中

  • 封装一个bean直接来接收

  • 原生的HttpServletRequest接收

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/664727.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

3d渲染的常用概念和技术,渲染100邀请码1a12

之前我们介绍了3D渲染的基本原理和流程&#xff0c;这次说下几个常用概念和技术。 3D渲染中涉及到很多专业的概念和技术&#xff0c;它们决定了渲染质量和效果&#xff0c;常用的有以下几个。1、光线追踪 光线追踪是一些专业渲染器&#xff08;如V-Ray和Corona等&#xff09;…

算法思想总结:哈希表

一、哈希表剖析 1、哈希表底层&#xff1a;通过对C的学习&#xff0c;我们知道STL中哈希表底层是用的链地址法封装的开散列。 2、哈希表作用&#xff1a;存储数据的容器&#xff0c;插入、删除、搜索的时间复杂度都是O&#xff08;1&#xff09;&#xff0c;无序。 3、什么时…

Android HIDL接口添加

一.HIDL介绍 HIDL的全称是HAL interface definition language&#xff08;硬件抽象层接口定义语言&#xff09;&#xff0c;是Android Framework 与Android HAL之间的接口。HIDL 旨在用于进程间通信 (IPC)&#xff0c;进程之间的通信 采用 Binder 机制。 二.HIDL 与AIDL 的对…

客户文章|难能可贵,非模式生物的功能研究与创新

菜豆&#xff08;Phaseolus vulgaris&#xff09;&#xff0c;又名四季豆、芸豆、油豆角&#xff0c;是全球第一大豆类蔬菜&#xff0c;我国是世界上最主要的菜豆生产国和销售国。在田间生产过程中&#xff0c;菜豆常面临着各种生物和非生物逆境的胁迫&#xff0c;对其产量品质…

FOC - BLDC六步换相驱动原理

文章目录 1 . 前言2 . 电机旋转原理3 . BLDC特点4 . BLDC反电动势投影位置5 . BLDC换相时刻6 . BLDC换相注意事项7 . 小结 【全文大纲】 : https://blog.csdn.net/Engineer_LU/article/details/135149485 1 . 前言 无刷直流电机在这里区分为两种&#xff0c;一是永磁无刷直流电…

【Linux-LCD 驱动】

Linux-LCD 驱动 ■ Framebuffer 简称 fb■ LCD 驱动程序编写■ 1、LCD 屏幕 IO 配置■ 2、LCD 屏幕参数节点信息修改■ 3、LCD 屏幕背光节点信息■ 4、使能 Linux logo 显示 ■ 设置 LCD 作为终端控制台■ 1、设置 uboot 中的 bootargs■ 2、修改/etc/inittab 文件 ■ LCD 背光…

python前端streamlit模型部署

简单介绍使用前端streamlit框架快速部署本地模型&#xff1a; 1、模型训练&#xff1a; import pandas as pd # 流程整合 from sklearn.pipeline import make_pipeline, Pipeline # 数据处理 from sklearn.impute import SimpleImputer from sklearn.preprocessing import Min…

探索 Android Studio 中的 Gemini:加速 Android 开发的新助力

探索 Android Studio 中的 Gemini&#xff1a;加速 Android 开发的新助力 在 Gemini 时代的下一篇章中&#xff0c;Gemini融入了更多产品中&#xff0c;Android Studio 正在使用 Gemini 1.0 Pro 模型&#xff0c;使 Android 开发变得更快、更简单。 Studio Bot 现已更名为 And…

深度学习知识与心得

目录 深度学习简介 传统机器学习 深度学习发展 感知机 前馈神经网络 前馈神经网络&#xff08;BP网络&#xff09; 深度学习框架讲解 深度学习框架 TensorFlow 一个简单的线性函数拟合过程 卷积神经网络CNN&#xff08;计算机视觉&#xff09; 自然语言处理NLP Wo…

C# WinForm —— 23 Timers.Timer 组件介绍与使用

1. 简介 System.Timers.Timer 计时器 轻量 每隔一段时间触发Elapsed事件&#xff0c;执行操作(不是由UI线程执行的)&#xff0c;即使事件中执行了比较耗时的操作&#xff0c;也不会造成 UI 失去响应 如果要获取服务器的计时功能的话&#xff0c;可以使用System.Timers.Timer …

unity2020打包webGL时卡进程问题

我使用的2020.3.0f1c1&#xff0c;打包发布WEB版的时候会一直卡到asm2wasm.exe这个进程里&#xff0c;而且CPU占用率90%以上。 即使是打包一个新建项目的空场景也是同样的问题&#xff0c;我尝试过一直卡在这里会如何&#xff0c;结果还真打包成功了。只是打包一个空场景需要20…

C++(入门基础版本)

1&#xff0c;什么是C C 是一种通用的、面向对象的编程语言&#xff0c;是 C 语言的一个超集&#xff0c;也就是说&#xff0c;任何有效的 C 程序都是有效的 C 程序。C 通过添加诸如类和对象、继承和多态等概念&#xff0c;扩展了 C 语言的功能&#xff0c;使其更适用于大型软…

CSS学习笔记目录

CSS学习笔记之基础教程&#xff08;一&#xff09; CSS学习笔记之基础教程&#xff08;二&#xff09; CSS学习笔记之中级教程&#xff08;一&#xff09; CSS学习笔记之中级教程&#xff08;二&#xff09; CSS学习笔记之中级教程&#xff08;三&#xff09; CSS学习笔记之高级…

国产身份域管架构图集合(信创政策AD域替换必看)

几类典型架构 双机架构 单点单机房 集群架构 多点单机房 两地三中心架构 多点多机房 多地分布式架构 多点多机房 全栈信创方案架构&#xff0c;欢迎探讨交流~

[数据集][目标检测]喝水检测数据集VOC+YOLO格式995张3类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;995 标注数量(xml文件个数)&#xff1a;995 标注数量(txt文件个数)&#xff1a;995 标注类别…

校园导航系统C++

制作一个简单的大学城导航系统&#xff0c;根据用户指定的起点和终点&#xff0c;求出最短路径长度以及具体路径。 项目要求&#xff1a; 1&#xff09;程序与数据相分离&#xff0c;地图中的所有数据都是从文件读入&#xff0c;而不是写在代码中 2&#xff09;最短路径算法…

抖音电商经验分享,揭秘做好抖店的七个关键细节,不容忽视

大家好&#xff0c;我是电商花花。 随着抖音电商和大量商家的不断入驻&#xff0c;大家对于电商的玩法也逐渐变多&#xff0c;拿到结果的商家也是越来越多&#xff0c;更多的做店玩法和步骤被更多人熟知。 现在想要做好抖店&#xff0c;其实也没有想象中那么复杂和困难。 新…

网络安全基础技术扫盲篇名词解释之“证书“

用通俗易懂的话说&#xff1a; 证书就好比是一张身份证&#xff08;类似&#xff0c;但不完全相同&#xff09;&#xff0c;用来证明一个网站的身份是否可信。就像你要确认一个陌生人的身份需要看他的身份证一样&#xff0c;电脑在连接一个网站时&#xff0c;也会查看网站的证…

停车场车位引导系统方案升级实施步骤流程是什么,有什么注意事项

停车场车位引导系统是一种现代化的停车管理系统&#xff0c;它通过实时监测车位占用情况&#xff0c;并向驾驶员提供准确的空闲车位导航信息&#xff0c;从而提高停车场的使用效率和用户体验。随着城市交通的快速发展和车辆数量的不断增加&#xff0c;停车场车位引导系统已成为…

树形结构-CRUD接口

先看一下效果&#xff1a;整体的效果 新增效果 --默认值是 default 修改效果 - 大致效果如上 --------------------------------------------------------------------------------------------------------------------------------- 下面讲解代码如何实现的 根据你使用…