首页 > 其他分享 >Go语言【Gin框架】:JSON、AsciiJSON、PureJSON和SecureJSON的区别

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

时间:2025-01-20 15:54:47浏览次数:1  
标签:字符 SecureJSON PureJSON JSON AsciiJSON ASCII

在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 main

import (
	"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。如果要按字面对这些字符进行编码,则可以使用 PureJSON
	r.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攻击。

标签:字符,SecureJSON,PureJSON,JSON,AsciiJSON,ASCII
From: https://www.cnblogs.com/ggyt/p/18681602

相关文章

  • cpp struct json相互转换
    C++结构体与JSON的相互转换在现代软件开发中,数据的序列化和反序列化是一个常见的需求。尤其在客户端和服务器之间的数据交换中,JSON因其简单、易读和良好的兼容性而被广泛使用。本文将介绍如何在C++中实现结构体和JSON之间的相互转换,重点介绍使用 nlohmann/json库。nlohmann/jso......
  • 【转】[JavaScript] JS 对象和 JSON 的区别与转换
    转自:kimi.ai在JavaScript中,JS对象和JSON是两个密切相关但又有所区别的概念。以下是它们的主要区别:1. 定义和用途JS对象JS对象是JavaScript中的一种数据结构,用于存储键值对(key-valuepairs)。它是JavaScript中的基本数据类型之一,可以用来表示复杂的数据结构,例如用......
  • [实现Rpc] 环境搭建 | JsonCpp | Mudou库 | callBack()
    目录1.项目介绍2.技术选型3.开发环境和环境搭建Ubuntu-22.04环境搭建1.安装wget(一般情况下默认会自带)2.更换国内软件源①备份原始/etc/apt/sources.list文件②编辑软件源文件③更新软件包列表3.安装常用工具3.1安装lrzsz传输工具3.2安装编译器gcc......
  • gorm - datatypes.JSONQuery 多种 JSON 查询方式
    一.官方:https://github.com/go-gorm/datatypes 二.modeltypeUserstruct{Name`gorm:"column:name;type:varchar(255);`Attributesdatatypes.JSON`gorm:"column:attributes;type:json"`}//数据内容user:=model.Us......
  • spring +fastjson 的 rce
    前言众所周知,spring下是不可以上传jsp的木马来rce的,一般都是控制加载class或者jar包来rce的,我们的fastjson的高版本正好可以完成这些,这里来简单分析一手一、环境搭建<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-s......
  • JSON.stringify有什么局限性和哪些技巧?
    JSON.stringify是JavaScript中用于将对象转换为JSON字符串的方法,但它在某些情况下具有局限性,同时也有一些技巧可以帮助开发者更有效地使用它。以下是关于JSON.stringify的局限性和技巧的详细解答:局限性:循环引用问题:当对象之间存在循环引用时,JSON.stringify会抛出错误。例如,一......
  • 使用python+pytest+requests完成自动化接口测试(包括html报告的生成和日志记录以及层级
    一、API的选择我们进行接口测试需要API文档和系统,我们选择JSONPlaceholder免费API,因为它是一个非常适合进行接口测试、API测试和学习的工具。它免费、易于使用、无需认证,能够快速帮助开发者模拟常见的接口操作(增、删、改、查)。尤其对于我你们学习接口测试的初学开发者来说,它......
  • wordpress 从服务器收到预料之外的响应。此文件可能已被成功上传。请检查媒体库或刷新
    两种报错方式:1.此响应不是合法的JSON响应。2.从服务器收到预料之外的响应。此文件可能已被成功上传。请检查媒体库或刷新本页。情况:媒体服务器上传小文件没问题,大一点的文件报这个错误。原因:这是因为nginx限制了请求体大小方案:需要在nginx的虚拟机配置文件中添加:client_max_b......
  • Jsoncpp的安装与使用方式
    JsonCpp是一个C++库,用于解析和生成JSON数据。它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式。安装Jsoncpp我们可以输入以下命令安装jsoncpp库。sudoyuminstall-yjsoncpp-devel安装时默认安装动态库。头文件存储在/usr/include/jsoncpp/json中。......
  • Json 序列化,将对象序列化为Json字符串(此Json序列化,是“不安全的放松JSON转义”,即不会
    ///<summary>///Json序列化帮助类///</summary>publicclassJsonSerializerHelper{///<summary>///将对象序列化为Json字符串(此Json序列化,是“不安全的放松JSON转义”,即不会将物特殊符号和中文进行转码)///</summary>///<paramname="obj"></param>......