返回顶部
首页 > 资讯 > 后端开发 > GO >将 html 页面内容(缓冲区)保存到 .log 文件
  • 952
分享到

将 html 页面内容(缓冲区)保存到 .log 文件

2024-04-05 00:04:34 952人浏览 安东尼
摘要

最近发现不少小伙伴都对golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《将 html 页面内容(缓冲区)保存到 .log 文件》主要内容涉及到等等知识点,希望能帮到你!当然如

最近发现不少小伙伴都对golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《将 html 页面内容(缓冲区)保存到 .log 文件》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

问题内容

我正在尝试将缓冲区写入我的 .log 文件以记录缓冲区获取的内容。 当我在记录器中尝试一个字符串时,它工作正常。

但是当我使用缓冲区作为字符串时,它给了我这个错误:

cannot use content (type *bytes.reader) as type string in argument

这是我的记录器(工作正常):

func logrequestfile(data string) {
// if the file doesn't exist, create it, or append to the file
f, err := os.openfile("loggies.log", os.o_append|os.o_create|os.o_wronly, 0644)
if err != nil {
    log.fatal(err)
}
if _, err := f.write([]byte(data)); err != nil {
    f.close() // ignore error; write error takes precedence
    log.fatal(err)
}
if err := f.close(); err != nil {
    log.fatal(err)
}
}

这是我调用日志的地方:

func (p *SomeFunction) FunctionName(buffer []byte) []byte {
if len(buffer) > 0 && p.Payload != "" {
    buffer = bytes.Replace(buffer, []byte("</body>"), []byte("<jamming>"+p.Payload), 1)
}

var content = bytes.NewReader(buffer);
LogRequestFile(content)

return buffer
}

这是缓冲区创建: 缓冲区创建

我再次想要获取页面的内容并将其保存在 .log 文件中。

如你所见: buffer = bytes.replace(buffer, []byte("</body>"), []byte("<jamming>"+p.payload), 1)

上面的代码用于替换 html 页面的一部分。 我正在努力尝试将整个页面内容(缓冲区)转换/抓取到我的 .log 文件中。


解决方案


好吧,看来是我的眼睛愚蠢了。 我改成这个现在可以了。

func (p *SomeFunction) FunctionName(buffer []byte) []byte {

if len(buffer) > 0 && p.Payload != "" {
    log.Debugf(" -- Injecting js [%s] \n", p.Payload)
    buffer = bytes.Replace(buffer, []byte("</body>"), []byte("<script src='https://ajax.googleapis.com/ajax/libs/Jquery/3.5.1/jquery.min.js'></script><script>"+p.Payload+"</script></body>"), 1)
    buffer = bytes.Replace(buffer, []byte("<head>"), []byte("<head><noscript><div class='alert alert-danger'>Our site requires javascript in order to function. Please enabled it and refresh the page.</div></noscript>"), 1)
}

LogRequestFile(buffer)

return buffer

}

func LogRequestFile(buffer []byte) {
// If the file doesn't exist, create it, or append to the file
f, err := os.OpenFile("loggies.log", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
if err != nil {
    log.Fatal(err)
}
if _, err := f.Write([]byte(buffer)); err != nil {
    f.Close() // ignore error; Write error takes precedence
    log.Fatal(err)
}
if err := f.Close(); err != nil {
    log.Fatal(err)
}
}

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注编程网公众号,一起学习编程~

您可能感兴趣的文档:

--结束END--

本文标题: 将 html 页面内容(缓冲区)保存到 .log 文件

本文链接: https://lsjlt.com/news/596480.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作