-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfetchDebug.tsx
55 lines (53 loc) · 1.86 KB
/
fetchDebug.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import { JSONSTRINGIFYNULL4 } from "./JSONSTRINGIFYNULL4.ts";
// 异步函数,发送一个用于调试的请求
/**
* 异步函数fetchDebug用于发送请求并打印请求和响应的详细信息
* @param input 请求的URL或URL对象
* @param init 可选参数,请求的初始化配置,如方法、头信息等
* @returns 返回一个Promise,解析为响应对象Response
*/
export async function fetchDebug(
input: RequestInfo | URL, // 请求的URL或URL对象
init?: RequestInit | undefined, // 请求的初始化配置,可选参数
): Promise<Response> {
// 返回一个Promise<Response>
const request = new Request(input, init); // 创建一个Request对象
const { url, method, headers } = request; // 获取URL、请求方法和请求头信息
console.log(
JSONSTRINGIFYNULL4(
{
request: {
// 打印请求信息
url,
method,
headers: Object.fromEntries(headers),
},
},
null,
4,
),
);
const response = await fetch(request); // 发送请求并获取响应
console.log(
JSONSTRINGIFYNULL4(
{
response: {
// 打印响应信息
// url: request.url, // 请求的URL
status: response.status, // 响应状态码
// method, // 请求方法
headers: Object.fromEntries(response.headers), // 响应头信息
},
request: {
// 打印请求信息
url,
method,
headers: Object.fromEntries(headers),
},
},
null,
4,
),
);
return response; // 返回响应对象
}