访问附加到ELF二进制文件的数据

reg*_*fry 5 linux gcc build elf

我有一个静态ELF二进制文件,它从zip文件中读取数据.为了简化分发,我想将zipfile附加到二进制文件,如下所示:

$ cat mydata.zip >> mybinary
Run Code Online (Sandbox Code Playgroud)

我知道这样做不会损害mybinary,但我不知道如何访问mydata.zip的内容.可能吗?如果是这样,怎么样?

在过去,我使用了附加数据然后附加数据长度的技巧,因此我所要做的就是打开二进制文件,读取流的最后一个int,回退那个长度然后开始解压缩,但是由于各种原因在这里不起作用(例如,我不能保证当需要zipfile时文件仍然在光盘上).

如果解决方案适用于OS X和MinGW,那么全面超级双倍加分.

Pet*_*esh 3

假设在应用程序执行开始时您可以访问该文件,那么打开该文件的句柄应该可以防止操作系统删除磁盘上的文件,直到对该文件的最后一个引用被关闭。这将允许您在文件中查找您想要的内容,使用该文件句柄而无需担心。

创建一个全局变量:

int app_fd;
Run Code Online (Sandbox Code Playgroud)

其中大多数的过程是相同的,在主例程中,只需发出:

app_fd = open(argv[0], O_RDONLY);
Run Code Online (Sandbox Code Playgroud)

在执行开始时。当执行过程中需要访问 zip 文件时,只需使用文件描述符,而不是文件名。

在运行时,如果您没有某种形式的应用程序原始内容句柄,那么您可能无法访问 zip 文件的内容。这是因为加载程序仅映射文件中预期的部分。二进制文件末尾的内容将被视为垃圾并且不会被映射。

要完成将 zip 文件映射到内存中,您需要遵循不同的策略。您需要将 .zip 嵌入到二进制文件的 ELF(linux)/COFF(Windows)/Mach-O(Mac OS X) 部分,该部分具有设置的属性,以便保证映射到应用程序中(这需要应用程序中有很多前期工作,处理过程中有很多后期工作)。这并不是一件小事,可能需要相当多的编码才能使其适合每个平台。

顺便说一句,在应用程序运行时从 Windows 系统中删除该应用程序并不是一件容易的事(我认为如果它驻留在 NTFS 上,您可以移动它)。