【摘要】go语言编译出来的二进制文件中,字符串数据是如何存放的,逆向时如何快速和准确的识别出源代码中定义的字符串,本文给你解密。
**Go语言源代码编译成二进制文件后,源代码中的字符串存放在哪里?是如何组织的?**
以下面go语言源代码为例:\
package main\
import “fmt”\
func main() {\
fmt.Println(“Hello, World!”)\
}
虽然只是打印一个字符串"Hello, World!",生成的二进制文件中字符串却是非常的多:\
![image.png](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/dbd8142cfc6f41329b1968821ec8777a~tplv-k3u1fbpfcp-zoom-1.image)
Go语言二进制文件中字符串是存放在哪里的呢?其实存放的位置遵循的elf格式原则,在.rodata节中(**如上图所示**)。
有同学会问C语言编译出来的elf格式中字符串也是这样存放的,Go语言的字符串组织方法和C语言的字符串组织方法有什么不同的呢?最大的不同点就是C语言字符串是以’\x00’结尾的,这样不同字符串之间可以方便的以’\x00’来切割,而Go语言的字符串你可以发现是没有’\x00’结尾的,比如上图中"Hello, World!"后面紧接着就是"SIGKILL:"了,没有’\x00’分隔。
**Go语言字符串按以下方法来组织:**
- 字符串按长度从小到大排列
- 相同长度的字符串按字符比较的方法从小到大排列
- 非可见字符串先转义再存放
另外Go语言字符串一般从**go_str