当前位置: 首页 > news >正文

一篇梳理清楚http请求知识点

HTTP请求是Web开发中的重要组成部分,它涉及到客户端和服务器之间的通信。掌握HTTP请求的知识点对于前端开发和后端开发都至关重要。以下是关于HTTP请求的详细梳理,结合代码进行说明。

1. HTTP请求概述

HTTP(超文本传输协议)是一个客户端(通常是浏览器)与服务器之间的通信协议。它定义了请求和响应的格式,支持各种类型的操作,如获取网页内容、提交表单数据、获取资源等。

HTTP请求由以下几个部分组成:

  • 请求行(Request Line)
  • 请求头(Request Headers)
  • 请求体(Request Body)

2. 请求行(Request Line)

请求行包含三部分内容:

  • 请求方法(GET, POST, PUT, DELETE等)
  • 请求目标(通常是URL)
  • HTTP版本(通常是HTTP/1.1HTTP/2

例如:

GET /index.html HTTP/1.1

表示客户端通过GET方法请求服务器上的/index.html资源,使用HTTP/1.1协议。

3. 常见的HTTP请求方法

GET

GET请求用于获取数据,通常用于浏览器访问网页时。GET请求的参数会附加在URL后面,通过?进行分隔。例如:

fetch('https://api.example.com/data?id=123&name=abc').then(response => response.json()).then(data => console.log(data));

GET请求的特性:

  • 无请求体(数据通过URL传递)
  • 请求内容可以被缓存
  • 长度有限制(URL的长度通常不超过2048个字符)
POST

POST请求用于向服务器发送数据,通常用于提交表单或上传文件。POST请求的数据通过请求体传递。例如:

fetch('https://api.example.com/data', {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify({ id: 123, name: 'abc' })
}).then(response => response.json()).then(data => console.log(data));

POST请求的特性:

  • 请求体用于传递数据
  • 数据量较大,适合提交复杂的表单或上传文件
  • 不会将数据暴露在URL中
PUT

PUT请求通常用于更新资源。与POST不同,PUT请求是幂等的,意味着多次执行相同的PUT请求结果是一样的。例如:

fetch('https://api.example.com/data/123', {method: 'PUT',headers: {'Content-Type': 'application/json'},body: JSON.stringify({ id: 123, name: 'updated' })
}).then(response => response.json()).then(data => console.log(data));

PUT请求的特性:

  • 请求体包含更新后的资源数据
  • 一般用于更新现有资源
DELETE

DELETE请求用于删除服务器上的资源。例如:

fetch('https://api.example.com/data/123', {method: 'DELETE'
}).then(response => response.json()).then(data => console.log(data));

DELETE请求的特性:

  • 用于删除资源
  • 请求体通常为空

4. 请求头(Request Headers)

请求头包含关于客户端环境和请求的额外信息。常见的请求头字段有:

  • Content-Type:指定请求体数据的类型(如application/json, application/x-www-form-urlencoded等)
  • Authorization:用于携带身份验证信息
  • Accept:客户端希望接受的响应内容类型(如text/html, application/json等)
  • User-Agent:客户端的浏览器或应用程序信息

例如,发送一个包含JSON数据的POST请求时:

fetch('https://api.example.com/data', {method: 'POST',headers: {'Content-Type': 'application/json','Authorization': 'Bearer token_here'},body: JSON.stringify({ id: 123, name: 'abc' })
}).then(response => response.json()).then(data => console.log(data));

5. 请求体(Request Body)

请求体用于发送数据给服务器。在POSTPUT等请求方法中,数据通常通过请求体发送。常见的数据格式有:

  • JSON:application/json
  • 表单数据:application/x-www-form-urlencoded
  • 文件上传:multipart/form-data

6. HTTP响应

HTTP响应包含以下几个部分:

  • 状态行(Status Line):包含响应的状态码和状态消息。
  • 响应头(Response Headers):包含服务器和响应的相关信息。
  • 响应体(Response Body):包含返回的数据内容。

例如,服务器响应的状态行可能是:

HTTP/1.1 200 OK

表示请求成功,返回了200状态码。

7. HTTP状态码

状态码用于表示服务器对请求的处理结果。常见的状态码包括:

  • 200 OK:请求成功
  • 201 Created:请求成功,并创建了新的资源
  • 400 Bad Request:请求无效,可能是参数错误
  • 401 Unauthorized:身份验证失败
  • 404 Not Found:请求的资源不存在
  • 500 Internal Server Error:服务器发生错误

8. 使用JavaScript发送HTTP请求

在现代浏览器中,发送HTTP请求常用的两种方法是:

  1. XMLHttpRequest
  2. fetch API
1. 使用XMLHttpRequest
var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://api.example.com/data', true);
xhr.setRequestHeader('Accept', 'application/json');
xhr.onload = function () {if (xhr.status === 200) {console.log(JSON.parse(xhr.responseText));}
};
xhr.send();
2. 使用fetch API

fetch是现代浏览器支持的API,它比XMLHttpRequest更简洁,支持Promise,使得处理异步请求更加方便。

fetch('https://api.example.com/data').then(response => response.json()).then(data => console.log(data)).catch(error => console.error('Error:', error));

9. 跨域请求(CORS)

跨域请求(Cross-Origin Resource Sharing,CORS)是指在浏览器中,前端页面尝试从不同源(不同域名、端口或协议)的服务器请求资源时,浏览器会进行限制。服务器需要通过Access-Control-Allow-Origin等响应头来允许跨域请求。

例如,允许所有源进行跨域请求:

Access-Control-Allow-Origin: *

总结

HTTP请求是前后端通信的基础,掌握其基本结构和请求方式非常重要。通过GETPOSTPUTDELETE等方法可以实现不同的功能,而请求头和请求体提供了更多的配置和数据传输方式。掌握这些基本的请求机制后,可以更好地处理客户端与服务器之间的数据交互。

http://www.lryc.cn/news/507829.html

相关文章:

  • Kotlin - 协程结构化并发Structured Concurrency
  • 新版国标GB28181设备端Android版EasyGBD支持国标GB28181-2022,支持语音对讲,支持位置上报,开源在Github
  • 豆包MarsCode测评:编程效率再提升
  • 二叉树 -- 堆(详解)
  • 【Apache Paimon】-- 11 -- Flink 消费 kakfa 写 S3 File
  • SQL MID()
  • jsp | servlet | spring forEach读取不了对象List
  • 【ArcGIS Pro微课1000例】0063:处理无人机数据(空三、生成DOM、DSM、DTM)
  • 【pytorch】深度学习计算
  • 详解磁盘IO、网络IO、零拷贝IO、BIO、NIO、AIO、IO多路复用(select、poll、epoll)
  • VPN技术-GRE隧道的配置
  • 【spring-cloud-gateway总结】
  • 数组相关简单算法
  • 在VBA中结合正则表达式和查找功能给文档添加交叉连接
  • 动手学深度学习-多层感知机-7前向传播、反向传播和计算图
  • 【Python】基于Python的CI/CD工具链:实现自动化构建与发布
  • FPGA-PS端编程1:
  • 自制数据库迁移工具-C版-06-HappySunshineV1.5-(支持南大Gbase8a、PostgreSQL、达梦DM)
  • 了解RPC
  • centos7 安装docker
  • Docker 入门:如何使用 Docker 容器化 AI 项目(一)
  • LLMs之rStar:《Mutual Reasoning Makes Smaller LLMs Stronger Problem-Solvers》翻译与解读
  • 【RK3588 Linux 5.x 内核编程】-内核中断与ThreadedIRQ
  • Message Processing With Spring Integration高级应用:自定义消息通道与端点
  • S32K324 MCAL中的Postbuild和PreCompile使用
  • kubeadm_k8s_v1.31高可用部署教程
  • 【AI日记】24.12.22 容忍与自由 | 环境因素和个人因素
  • 【Java基础面试题030】Java和Go的区别?
  • 学习嵩山版《Java 开发手册》:编程规约 - 常量定义(P5)
  • 洛谷 P1595 信封问题 C语言递归