使用 io.Reader 将 HTML 实体解码
来源:stackoverflow
时间:2024-03-07 23:24:31 168浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《使用 io.Reader 将 HTML 实体解码》,聊聊,我们一起来看看吧!
我的 go 程序发出 http 请求,其响应正文是大型 json 文档,其字符串将 & 符号 &
编码为 &
(可能是由于某些 microsoft 平台怪癖?)。我的程序需要以与 json.decoder
兼容的方式将这些实体转换回 & 符号。
示例响应可能如下所示:
{"name":"a&b","comment":"foo&bar"}
其对应的对象如下:
pkg.Object{Name:"A&B", Comment:"foo&bar"}
文档的形状多种多样,因此在解码后转换 html 实体是不可行的。理想情况下,可以通过将响应正文读取器包装在另一个执行转换的读取器中来完成。
有没有一种简单的方法可以将 http.response.body
包装在某些 io.readcloser
中,从而用 &
替换 &
的所有实例(或者在一般情况下,用字符串 y 替换任何字符串 x)?
我怀疑 x/text/transform
是可能的,但不立即知道如何实现。特别是,我担心实体跨越批量字节的边缘情况。也就是说,例如,一个批次以 &am
结束,下一批以 p;
开始。是否有一些库或习惯用法可以优雅地处理这种情况?
解决方案
如果您不想依赖像 transform.reader
这样的外部包,您可以编写自定义 io.reader
包装器。
以下内容将处理 find
元素可能跨越两个 read()
调用的边缘情况:
type fixer struct { r io.reader // source reader fnd, rpl []byte // find & replace sequences partial int // track partial find matches from previous read() } // read satisfies io.reader interface func (f *fixer) read(b []byte) (int, error) { off := f.partial if off > 0 { copy(b, f.fnd[:off]) // copy any partial match from previous `read` } n, err := f.r.read(b[off:]) n += off if err != io.eof { // no need to check for partial match, if eof, as that is the last read! f.partial = partialfind(b[:n], f.fnd) n -= f.partial // lop off any partial bytes } fixb := bytes.replaceall(b[:n], f.fnd, f.rpl) return copy(b, fixb), err // preserve err as it may be io.eof etc. }
连同这个助手(可能需要一些优化):
// returns number of matched bytes, if byte-slice ends in a partial-match func partialFind(b, find []byte) int { for n := len(find) - 1; n > 0; n-- { if bytes.HasSuffix(b, find[:n]) { return n } } return 0 // no match }
注意:要测试边缘情况逻辑,可以使用 narrowreader
来确保 read
很短,并强制将匹配项拆分到 read
,如下所示:validation playground example
今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习