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

【Gin】HTTP 请求调试器

文章目录

    • 项目概述
    • 代码功能详解
      • 1. 导入必要的包
      • 2. 主函数和路由设置
      • 3. 请求信息捕获
      • 4. 请求参数和头信息
      • 5. 请求体处理
        • 5.1 JSON 数据处理
        • 5.2 表单数据处理
        • 5.3 Multipart 表单数据处理
        • 5.4 其他类型数据处理
      • 6. 构造响应对象
      • 7. 返回 JSON 响应
    • 功能特点
    • 使用场景
    • 完整代码

项目概述

这个 Gin HTTP 请求调试器是一个功能完整的工具,用于测试和调试前端接口调用。它能够捕获并记录所有请求信息,并以清晰的结构化方式展示这些信息。这个工具特别适合 API 开发、Webhook 调试、第三方服务集成验证等场景。

代码功能详解

1. 导入必要的包

import ("encoding/json""fmt""io""net/http""strings""time""github.com/gin-gonic/gin"
)
  • encoding/json: 用于 JSON 数据的编码和解码
  • fmt: 用于格式化输入输出
  • io: 提供基本的 I/O 操作
  • net/http: 提供 HTTP 相关功能
  • strings: 提供字符串操作函数
  • time: 提供时间相关功能
  • github.com/gin-gonic/gin: Gin Web 框架,用于构建 HTTP 服务器

2. 主函数和路由设置

func main() {r := gin.Default()r.Any("/*path", func(c *gin.Context) {// 请求处理逻辑})// 启动服务fmt.Println("HTTP Request Debugger is running on http://localhost:8080")r.Run(":8080")
}
  • gin.Default(): 创建一个默认的 Gin 路由器
  • r.Any("/*path", ...): 定义一个通用的路由处理器,可以处理所有 HTTP 方法
  • r.Run(":8080"): 启动 HTTP 服务器,监听 8080 端口

3. 请求信息捕获

// 获取请求基本信息
url := c.Request.URL.String()
method := c.Request.Method
protocol := c.Request.Proto
host := c.Request.Host
path := c.Param("path")
clientIP := c.ClientIP()
timestamp := time.Now().Format("2006-01-02 15:04:05.000")
requestID := fmt.Sprintf("%d", time.Now().UnixNano())
  • url: 完整的请求 URL
  • method: HTTP 方法(GET, POST, PUT, DELETE 等)
  • protocol: HTTP 协议版本(如 HTTP/1.1)
  • host: 请求的主机名
  • path: 请求路径
  • clientIP: 客户端的 IP 地址
  • timestamp: 请求时间戳,精确到毫秒
  • requestID: 唯一的请求 ID,基于时间戳生成

4. 请求参数和头信息

// 获取请求参数
params := c.Request.URL.Query()
// 获取请求头
headers := make(map[string]string)
for k, v := range c.Request.Header {headers[k] = strings.Join(v, ", ")
}
  • params: 获取 URL 查询参数
  • headers: 获取所有请求头信息,并转换为字符串形式的键值对

5. 请求体处理

// 处理不同类型的请求体
contentType := c.Request.Header.Get("Content-Type")
var data interface{}
var rawBody []byte
  • contentType: 获取请求体的内容类型
  • data: 用于存储解析后的请求数据
  • rawBody: 用于存储原始请求体
5.1 JSON 数据处理
if strings.Contains(contentType, "application/json") {// 处理JSON数据bodyBytes, err := io.ReadAll(c.Request.Body)if err != nil {c.JSON(http.StatusBadRequest, gin.H{"error": "cannot read body"})return}rawBody = bodyBytesvar jsonData map[string]interface{}if err := json.Unmarshal(bodyBytes, &jsonData); err == nil 
http://www.dtcms.com/a/270736.html

相关文章:

  • C/C++ 高频八股文面试题1000题(二)
  • Java中Map、List 和 Set 之间的常见转换方法总结
  • vcpkg交叉编译qt等过程记录(未完成)
  • HarmonyOS应用开发者高级试题2025年7月部分单选题(带答案)
  • 学习日记-spring-day44-7.9
  • C++随机打乱函数:简化源码与原理深度剖析
  • leetcode11.盛最多水的容器
  • Webpack、Vite配置技巧与CI/CD流程搭建全解析
  • 【RTSP从零实践】9、多播传输AAC格式的RTP包(附带源码)
  • mac m1安装大模型工具vllm
  • kotlin学习,val使用get()的问题
  • mysql 安装实战
  • Claude Code 开发使用技巧
  • User手机上如何抓取界面的布局uiautomatorviewer
  • Linux的`if test`和`if [ ]中括号`的取反语法比较 笔记250709
  • Unity Demo-3DFarm详解-其二
  • 以太坊智能合约核心技术解析与应用实践
  • LLaMA-Omni 深度解析:打开通往无缝人机语音交互的大门
  • HCIP 认证可以做什么?如何选择合适的职业路径?
  • C++11 future、promise实现原理
  • AI生成交互式数据图表
  • 【c++八股文】Day5:const和constexpr,define
  • sql查询davinci看板数据
  • 【一起来学AI大模型】PyTorch DataLoader 实战指南
  • 极简相册管理ios app Tech Support
  • ARM汇编编程(AArch64架构)课程 - 第7章:SIMD与浮点运算
  • 2025杰理蓝牙芯片:各系列芯片特点及市场分析
  • 【手写 new 操作符实现 - 深入理解 JavaScript 对象创建机制】
  • 【Linux】权限的概念及理解
  • VR/AR在HMI中的创新应用:远程协作与维修的沉浸式体验