Go语言实战案例:使用Gin处理路由参数和查询参数

在 Web API 开发中,处理 路由参数(Path Parameter)查询参数(Query Parameter) 是非常常见的需求。

Go 语言的 Gin 框架在这方面提供了简洁的 API,让你轻松获取和使用这些参数。

本文将通过一个完整的例子,带你掌握 Gin 中这两类参数的用法。


一、路由参数 vs 查询参数

1. 路由参数(Path Parameter)

  • • 出现在 URL 路径中

  • • 通常用于标识资源 ID

  • • 例如:

    bash 复制代码
    GET /users/123

    这里 123 就是路由参数 id

2. 查询参数(Query Parameter)

  • • 出现在 ? 后面,以 & 分隔

  • • 用于过滤、分页等非资源唯一标识的情况

  • • 例如:

    ini 复制代码
    GET /search?keyword=gin&page=2

二、Gin 获取路由参数和查询参数

Gin 通过 :param 定义路由参数,通过 c.Param() 获取;

查询参数可以用 c.Query()c.DefaultQuery() 获取。


三、示例代码

go 复制代码
package main

import (
    "github.com/gin-gonic/gin"
    "net/http"
)

func main() {
    r := gin.Default()

    // 路由参数示例
    r.GET("/users/:id", func(c *gin.Context) {
        id := c.Param("id")
        c.JSON(http.StatusOK, gin.H{
            "user_id": id,
        })
    })

    // 查询参数示例
    r.GET("/search", func(c *gin.Context) {
        keyword := c.Query("keyword")           // 没有默认值
        page := c.DefaultQuery("page", "1")     // 默认值为 1
        c.JSON(http.StatusOK, gin.H{
            "keyword": keyword,
            "page":    page,
        })
    })

    // 组合使用
    r.GET("/articles/:category", func(c *gin.Context) {
        category := c.Param("category")
        page := c.DefaultQuery("page", "1")
        c.JSON(http.StatusOK, gin.H{
            "category": category,
            "page":     page,
        })
    })

    r.Run(":8080")
}

四、运行与测试

启动服务:

go 复制代码
go run main.go

1. 测试路由参数

bash 复制代码
curl http://localhost:8080/users/42

返回:

json 复制代码
{"user_id":"42"}

2. 测试查询参数

arduino 复制代码
curl "http://localhost:8080/search?keyword=gin&page=2"

返回:

json 复制代码
{"keyword":"gin","page":"2"}

3. 路由参数 + 查询参数

arduino 复制代码
curl "http://localhost:8080/articles/golang?page=3"

返回:

json 复制代码
{"category":"golang","page":"3"}

五、注意事项

    1. 参数类型

    Gin 获取到的参数是字符串,如果需要整数或浮点数,需要手动转换:

    css 复制代码
    pageNum, err := strconv.Atoi(c.DefaultQuery("page", "1"))
    1. 路由冲突

    如果有多个类似 /users/:id 的路由,注意避免与静态路由冲突,比如 /users/list 可能会被解析成 id=list

    1. 默认值

    查询参数建议用 c.DefaultQuery() 设置默认值,避免出现空字符串或 nil。


六、总结

通过 Gin,我们可以非常简洁地处理:

  • • 路由参数:c.Param("name")
  • • 查询参数:c.Query("key") / c.DefaultQuery("key", "default")

在实际项目中,你可以将参数解析和验证抽取成中间件,提升代码可维护性。

相关推荐
天若有情6731 小时前
Java Swing 实战:从零打造经典黄金矿工游戏
java·后端·游戏·黄金矿工·swin
一只叫煤球的猫2 小时前
建了索引还是慢?索引失效原因有哪些?这10个坑你踩了几个
后端·mysql·性能优化
magic334165633 小时前
Springboot整合MinIO文件服务(windows版本)
windows·spring boot·后端·minio·文件对象存储
开心-开心急了3 小时前
Flask入门教程——李辉 第一、二章关键知识梳理(更新一次)
后端·python·flask
掘金码甲哥4 小时前
调试grpc的哼哈二将,你值得拥有
后端
小学鸡!4 小时前
Spring Boot实现日志链路追踪
java·spring boot·后端
用户21411832636025 小时前
OpenSpec 实战:用规范驱动开发破解 AI 编程协作难题
后端
Olrookie6 小时前
若依前后端分离版学习笔记(二十)——实现滑块验证码(vue3)
java·前端·笔记·后端·学习·vue·ruoyi
LucianaiB6 小时前
招聘可以AI面试,那么我制作了一个AI面试教练不过分吧
后端
无奈何杨7 小时前
CoolGuard更新,ip2region升级、名单增加过期时间
后端