Go语言【Gin框架】:JSON、AsciiJSON、PureJSON和SecureJSON的区别

news/2025/1/20 15:46:34/文章来源:https://www.cnblogs.com/ggyt/p/18681602

在Go语言中,JSONAsciiJSONPureJSONSecureJSON 是Gin框架用于发送JSON响应的方法。

1. c.JSON

功能:将提供的数据序列化为标准的JSON格式,并将其作为HTTP响应发送给客户端。

特点

  • 支持Unicode字符,无需将非ASCII字符转义。
  • 某些字符(如 <、> 和 &)会被自动转义为相应的 Unicode 转义序列。

使用场景

  • 需要发送包含Unicode字符(如中文、表情符号等)的JSON数据时。

2. c.AsciiJSON

功能:将数据序列化为仅包含ASCII字符的JSON格式,通过转义非ASCII字符确保JSON内容为ASCII编码。

特点

  • 所有非ASCII字符(如中文、特殊符号)会被转义为Unicode编码(如 \uXXXX)。

使用场景

  • 适用于需要确保JSON响应为纯ASCII的场景,例如某些旧版系统或特定的安全需求。
  • 客户端对JSON编码有严格要求,只接受ASCII字符。
  • 避免因非ASCII字符导致的读取或解析问题。

3. c.PureJSON

功能:发送未经额外处理的纯JSON数据,不进行任何包装或转义。

特点

  • 直接将提供的JSON数据发送给客户端。
  • 避免框架对JSON数据进行额外的修改。

使用场景

  • 已经预处理或生成了符合要求的JSON数据,且不希望框架进行任何干预。
  • 需要发送特定格式或结构的JSON响应时。

4. c.SecureJSON

功能:在JSON响应前添加安全前缀,以防止JSON Hijacking(JSON劫持)攻击。

特点

  • 通常在JSON数据前添加特定的字符或字符串(例如 ")]}',\n"),使得响应不再是有效的JavaScript代码,增加安全性。

使用场景

  • 适用于公开API或需要防范特定安全威胁的场景。
  • 提供跨域API时,防止恶意网站通过<script>标签加载JSON数据进行攻击。
  • 需要增强JSON响应的安全性,避免被恶意利用。

代码

package mainimport ("net/http""github.com/gin-gonic/gin"
)type User struct {Name  string   `json:"name"`Email string   `json:"email"`Names []string `json:"names"`
}func main() {// 创建默认的Gin引擎r := gin.Default()// 示例数据user := User{Name:  "张三", // 包含非ASCII字符Email: "zhangsan<@example.com>",Names: []string{"lena", "austin", "foo"},}// 路由1: 使用 c.JSON(标准JSON响应,支持Unicode)r.GET("/json", func(c *gin.Context) {c.JSON(http.StatusOK, user)// 输出:// {//   "name": "张三",//   "email": "zhangsan\u003c@example.com\u003e"//	 "names": ["lena","austin","foo"]// }})// 路由2: 使用 c.AsciiJSON(ASCII编码的JSON,非ASCII字符会被转义)r.GET("/ascii-json", func(c *gin.Context) {c.AsciiJSON(http.StatusOK, user)// 输出:// {//   "name": "\u5f20\u4e09",//   "email": "zhangsan\u003c@example.com\u003e"//	 "names": ["lena","austin","foo"]// }})// 路由3: 使用 c.PureJSON// JSON 使用 unicode 替换特殊 HTML 字符,例如 < 变为 \ u003c。如果要按字面对这些字符进行编码,则可以使用 PureJSONr.GET("/pure-json", func(c *gin.Context) {c.PureJSON(http.StatusOK, user)// 输出:// {"name":"张三","email":"zhangsan<@example.com>, "names":["lena","austin","foo"]}})// 路由4: 使用 c.SecureJSON(在JSON前添加安全前缀,防止JSON Hijacking攻击)// 如果给定的结构是数组值,则默认预置 "while(1)," 到响应体r.GET("/secure-json", func(c *gin.Context) {// 默认前缀为 ")];}',\n"c.SecureJSON(http.StatusOK, user)// 输出类似于:// )]}',// {//   "name": "张三",//   "email": "zhangsan\u003c@example.com\u003e"//	 "names": ["lena","austin","foo"]// }})// 启动服务器,监听8080端口r.Run(":8080")
}

总结

  • c.JSON:标准JSON响应,支持Unicode。
  • c.AsciiJSON:ASCII编码的JSON响应,非ASCII字符会被转义。
  • c.PureJSON:发送未经处理的原始JSON数据。
  • c.SecureJSON:在JSON前添加安全前缀,防止JSON Hijacking攻击。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/872189.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

海康web3.0插件开发,登录成功预览失败

做个记录,使用官方的demo,发现有登录成功,预览和回放失败,代码1000,未知错误,我遇到的情况是获取端口信息错误导致的这个是硬盘录像机原始的配置,虽然配置显示没有启用UPnP,但是插件中的默认获取的端口信息是按照这张表中的外部端口获取的,但是如果你没有启用端口映射…

Emacs 折腾日记(十)——elisp符号

符号是有名字的对象,这么说可能有点抽象。我们先来回忆一下C/C++中关于符号的内容。 C/C++ 最终被编译成机器码直接执行,在机器码中不存在变量名称,函数名称等字符,它只有一串地址。但是在写C/C++代码的时候有变量名,函数名,类名,对象名等等名称。编译器是如何做到将符号…

如何通过跨境电商流程管理工具提升项目效率?几个工具推荐

在竞争激烈的跨境电商领域,合适的工具就如同得力的助手,能够显著提升运营效率、优化业务流程,助力企业在全球市场中脱颖而出。从市场调研、选品采购,到店铺运营、营销推广以及物流管理等各个环节,都有相应的专业工具可供选择。接下来,我们将深入探讨一系列跨境电商实用工…

uniapp上传文件

1.h5不支持设置请求头,所有h5通过上述方式上传失败 2.如果前端不传图片需要用两种方式分别调用,且需要设置不同的请求头,后端需要同步更改 来源:https://blog.csdn.net/qq_23859799/article/details/126794172

2025.1.20 CSS基础

1、语法: 选择器{ 属性:值; 属性:值; ... } 例如: <html> <head> <meta charset="utf-8"> <style> p {color:red;text-align:center; } </style> </head><body> <p>Hello World!</p> <p>这个段…

小乌龟 svn 批量解锁方式

再次点击 get lock ,弹出来的框里面勾上“steal the lock” 强制获取锁 ok 之后,再来释放锁: 即可。

git密码带有特殊字符转义

git clone -b dev http://admin:%21%40%23%24%^abc%2C.%2F@xxx.gateway

Vim 操作

目录vi/vim 的使用命令模式输入模式底线命令模式vi/vim 按键说明移动光标的方法搜索替换删除、复制与贴上进入输入或取代的编辑模式快速移动光标在当前行上移动光标跨行移动光标翻页操作指令行的储存、离开等指令vim 环境的变更分屏操作vi/vim 的使用 VIM 常用的有四个模式:正…

NS3环境配置:NetAnim工具:通用安装

在NS3中需要使用进行网络可视化,其中工具NetAnim是官网源代码中所带工具: 编译NetAnim工具:cd netanim-3.109/ make clean qmake NetAnim.pro make 运行Netanim工具:cd netanim-3.109/ ./NetAnim 以上步骤通用于所有Netanim版本的安装

超大体积文本的快速打开查询EmEditor

前言 无法用grep精确查找日志内容的情况下,我会选择将日志文件拉到本地用文本编辑器打开查找关键信息 但有时候需要查看上百MB的日志文件,我们用常规的VsCode或者记事本打开容易出现卡死的问题 (据说win11的记事本倒是解决了这个问题) EmEditor 推荐使用EmEditor这个软件,…

请使用纯js实现一个横向或纵向的无缝滚动效果

以下是一个使用纯JavaScript实现的简单无缝滚动效果的示例。这个例子是横向滚动的,但你可以通过修改CSS和JavaScript中的某些部分来轻松实现纵向滚动。 HTML: <div id="scrollContainer"><div id="scrollContent"><img src="image1.j…

注解开发 -2025/1/19

纯注解开发bean管理 知识点1:@Autowired名称 @Autowired类型 属性注解 或 方法注解(了解) 或 方法形参注解(了解)位置 属性定义上方 或 标准set方法上方 或 类set方法上方 或 方法形参前面作用 为引用类型属性设置值属性 required:true/false,定义该属性是否允…