go学习笔记(17)Blob and ArrayBuffer

2023-12-09 22:15

本文主要是介绍go学习笔记(17)Blob and ArrayBuffer,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在学习go websocket的时候,在学习实验过程遇到一个比较奇怪问题。为什么我的数据返回是blob,而不是arrayBuffer?百思不得其解。

直到同事打包的时候微信小游戏遇到了一个报错。FileReader不支持。
经过在社区查询,官方答复是支持只是arraybuffer /string。那样在coco creator 调试的时候为什么返回的是blob? 而在微信的开发工作发现返回是Arraybuffer。

1.问题实验追踪

在今晚我尝试做了一个实验,在结合gpt 交流发现一个问题。首选我们以这样一个小案例进行实验。监听8080的端口,然后返回的时候进行打印。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>webSocket 返回类型问题</title>
</head>
<body>
<script type="text/javascript">const socket = new WebSocket('ws://localhost:8080');socket.onmessage = (event) => {if (event.data instanceof ArrayBuffer) {// 返回ArrayBuffer数据const arrayBuffer = event.data;// 打印二进制数据console.log('接收的二进制数据:', arrayBuffer);}};
</script>
</body>
</html>

在第一次返回的时候,监听这个数据,返回类型是Blob。的确是Blob类型。
在这里插入图片描述

好,进行第二次的设置,修改上述的代码,加入了一个属性。 socket.binaryType = “arraybuffer”; 设置返回类型。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>webSocket 返回类型问题</title>
</head>
<body>
<script type="text/javascript">const socket = new WebSocket('ws://localhost:8080');socket.binaryType = "arraybuffer"; //加入binaryType 指定返回类型socket.onmessage = (event) => {if (event.data instanceof ArrayBuffer) {// 返回ArrayBuffer数据const arrayBuffer = event.data;// 打印二进制数据console.log('接收的二进制数据:', arrayBuffer);}};
</script>
</body>
</html>

然后再次查看返回数据结果返回的类型变化了。猜测是只要设置了就能够返回指定数据。在没有设置类型的时候,默认是Blob类型。
在这里插入图片描述

看似简单的一个问题,没有留意就突然不知道怎么解释。以下为go测试代码。通过这样快速检测数据,则可以指定对应类型返回。

package mainimport ("fmt""github.com/gorilla/websocket""log""net/http"
)var upgrader = websocket.Upgrader{CheckOrigin: func(r *http.Request) bool {return true},
}func main() {http.HandleFunc("/", onMessage)err := http.ListenAndServe(":8080", nil)if err != nil {log.Fatal(err)}
}func onMessage(w http.ResponseWriter, r *http.Request) {conn, err := upgrader.Upgrade(w, r, nil)if err != nil {fmt.Println(err)return}defer conn.Close()data := make([]byte, 2)data[0] = 1data[1] = 2//发送 给客户端err = conn.WriteMessage(websocket.BinaryMessage, data)if err != nil {fmt.Println(err)return}
}

当h5 返回的是Blob的时候应该如何读取?改造一下读取方式。采用FileReader的方式进行读取。这样就可以满足到2种类型处理了。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>webSocket 返回类型问题</title>
</head>
<body>
<script type="text/javascript">const socket = new WebSocket('ws://localhost:8080');//socket.binaryType = "arraybuffer"; //加入binaryType 指定返回类型socket.onmessage = (event) => {if (event.data instanceof ArrayBuffer) {// 返回ArrayBuffer数据const arrayBuffer = event.data;// 打印二进制数据console.log('接收的二进制数据:', arrayBuffer);}else if(event.data instanceof  Blob){readBlob(event.data)}};function readBlob(blob){const reader = new FileReader();reader.onload = (event) => {// 获取读取的结果const result = event.target.result;if (result instanceof ArrayBuffer) {const arrayBuffer = result;// 打印二进制数据console.log('接收的二进制数据:', arrayBuffer);} else {console.error('Failed to read Blob as ArrayBuffer.');}};reader.readAsArrayBuffer(blob);}
</script>
</body>
</html>

在这里插入图片描述
同理这样可以解析到一个问题。数据返回需要设置一下就能返回指定的类型,在没有指定的时候就默认是Blob。而刚碰见微信小游戏不支持FileReader引发报错,而微信小游戏返回是直接ArrayBuffer。 这样就能解释并非引擎的问题。只是一个属性参数忘记设置导致的。

好了。今晚实验到此为止。

这篇关于go学习笔记(17)Blob and ArrayBuffer的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/475260

相关文章

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件