剔除Go编译文件的GOPATH信息

一人游走 · · 4714 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

当你panic,或者通过 runtime.Caller(0) 获取当前出错的文件位置作为日志记录时,会暴露你当时编译的项目路径、账户,下面这样可能并不是你想看到的。

panic: oh! no!
goroutine 1 [running]:
main.main()
        /Users/jerry/go/src/demo/panic_demo/main.go:10 +0x64

我们通过静态分析编译后的二进制 strings panic_demo | grep /Users 得到:

/Users/jerry/go/src/demo/panic_demo/main.go
/Users/jerry/go/src/demo/panic_demo/main.go
/Users/jerry/go/src/demo/panic_demo

经过我们处理后可以剔除此信息。

解决方式

go build -gcflags=-trimpath=$GOPATH -asmflags=-trimpath=$GOPATH

更彻底的方式

go build -gcflags=-trimpath=$GOPATH -asmflags=-trimpath=$GOPATH -ldflags "-w -s"

最终干净了,也不影响正常的堆栈信息。

panic: oh! no!
goroutine 1 [running]:
main.main()
        src/demo/myssl_demo/getcert_demo.go:10 +0x64

有疑问加站长微信联系(非本文作者)

本文来自:一人游走

感谢作者:一人游走

查看原文:剔除Go编译文件的GOPATH信息

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

4714 次点击  ∙  1 赞  
加入收藏 微博
1 回复  |  直到 2020-07-16 10:31:49
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传