为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

Go
慕娘9325324 2022-06-27 16:44:37
我正在尝试将缓冲区写入我的 .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 filef, 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 文件中。
查看完整描述

1 回答

?
烙印99

TA贡献1829条经验 获得超13个赞

好吧,看来是我的眼睛傻了。我现在改成这个了。


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)

}

}


查看完整回答
反对 回复 2022-06-27
  • 1 回答
  • 0 关注
  • 203 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号