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接收

  • 15
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Forever love..

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值