golang gin——中间件编程以及jwt认证和跨域配置中间件案例




package main
 
import (
    "fmt"
    "github.com/gin-gonic/gin"
    "net/http"
)
 
// JWT认证中间件
func JWTAuthMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        // 实现JWT认证逻辑
        // 例如,检查请求头中的Authorization字段
        // 如果认证失败,返回错误信息
        // 如果认证成功,调用c.Next()继续后续处理
        authorization := c.Request.Header.Get("Authorization")
        if authorization == "" {
            c.JSON(http.StatusUnauthorized, gin.H{"code": 401, "msg": "未认证"})
            c.Abort()
            return
        }
        // 假设jwtToken是从authorization字段中提取的token
        jwtToken := "从authorization字段提取的token"
        // 验证JWT token
        if jwtToken != "valid_token" {
            c.JSON(http.StatusUnauthorized, gin.H{"code": 401, "msg": "无效的token"})
            c.Abort()
            return
        }
        c.Next()
    }
}
 
// 跨域请求中间件
func CORSMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        c.Writer.Header().Set("Access-Control-Allow-Origin", "*")
        c.Writer.Header().Set("Access-Control-Max-Age", "86400")
        c.Writer.Header().Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE, UPDATE")
        c.Writer.Header().Set("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization")
        c.Writer.Header().Set("Access-Control-Expose-Headers", "Content-Length, Access-Control-Allow-Origin, Access-Control-Allow-Headers, Cache-Control, Content-Language, Content-Type")
        c.Writer.Header().Set("Access-Control-Allow-Credentials", "true")
 
        if c.Request.Method == "OPTIONS" {
            fmt.Println("Preflight request received!")
            c.AbortWithStatus(http.StatusNoContent)
        } else {
            c.Next()
        }
    }
}
 
func main() {
    r := gin.Default()
 
    // 使用JWT认证中间件
    r.Use(JWTAuthMiddleware())
    // 使用跨域请求中间件
    r.Use(CORSMiddleware())
 
    // 示例路由
    r.GET("/hello", func(c *gin.Context) {
        c.JSON(http.StatusOK, gin.H{"message": "Hello, World!"})
    })
 
    // 启动服务器
    r.Run(":8080")
}

这段代码演示了如何在Gin框架中编写JWT认证中间件和处理跨域请求的中间件。在这个例子中,我们假设JWT认证成功通过检查请求头中的Authorization字段,并返回一个简单的JSON响应。跨域中间件允许跨源请求,并设置了一些标准的CORS头部。在实际应用中,JWT认证逻辑和CORS策略会根据具体需求进行更复杂的配置。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日