- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
问题
我希望将目标文件注入(inject)现有的二进制文件。作为一个具体的例子,考虑一个源 Hello.c
:
#include <stdlib.h>
int main(void)
{
return EXIT_SUCCESS;
}
它可以通过gcc -std=gnu99 -Wall Hello.c -o Hello
编译成名为Hello
的可执行文件。此外,现在考虑 Embed.c
:
func1(void)
{
}
目标文件 Embed.o
可以通过 gcc -c Embed.c
创建。我的问题是如何将 Embed.o
一般地插入到 Hello
中,以执行必要的重定位和适当的 ELF 内部表(例如符号表、PLT、等)打补丁了吗?
假设
可以假设要嵌入的目标文件已经静态链接了它的依赖项。可以假定任何动态依赖项(例如 C 运行时)也存在于目标可执行文件中。
当前的尝试/想法
libbfd
将对象文件中的部分复制到二进制文件中。我在这方面取得的进步是我可以用原始二进制文件的部分和目标文件的部分创建一个新对象。问题在于,由于目标文件是可重定位的,因此如果不先执行重定位,就无法将其部分正确复制到输出中。ld
重新链接。到目前为止,我尝试使用 objcopy
执行转换 objcopy --input elf64-x86-64 --output elf64-x86-64 Hello Hello.o
。显然这并不像我预期的那样工作,因为 ld -o Hello2 Embed.o Hello.o
将导致 ld: error: Hello.o: unsupported ELF file type 2
.我想这应该是预料之中的,因为 Hello
不是目标文件。基本原理(可选阅读)
我正在制作一个静态可执行编辑器,其愿景是允许将任意用户定义的例程检测到现有的二进制文件中。这将分两步进行:
在大多数情况下,我已经完成了步骤 2 所需的工作,但是我在注入(inject)目标文件时遇到了问题。考虑到其他工具使用相同的对象注入(inject)方法(例如 EEL ),这个问题肯定是可以解决的。
最佳答案
如果是我,我会在共享对象 libembed.so
中创建 Embed.c
,如下所示:
gcc -Wall -shared -fPIC -o libembed.so Embed.c
这应该从 Embed.c
创建一个可重定位的共享对象。有了它,您可以通过在运行时设置环境变量 LD_PRELOAD
来强制您的目标二进制文件加载此共享对象(请参阅更多信息 here ):
LD_PRELOAD=/path/to/libembed.so Hello
这里的“技巧”是弄清楚如何进行检测,特别是考虑到它是一个静态可执行文件。在那里,我帮不了你,但这是将代码存在于进程内存空间中的一种方法。您可能希望在构造函数中进行某种初始化,您可以使用属性进行初始化(如果您使用的是 gcc
,至少):
void __attribute__ ((constructor)) my_init()
{
// put code here!
}
关于c - 如何将 'link' 目标文件转换为可执行/编译的二进制文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9449845/
所以问题是:如何使用标准 C 库以跨平台方式实现简单的自检可执行文件? 在这里,我正在寻找技术,而不是特定的检查方法(如 CRC 或哈希码),但该技术可能包含更适合某些方法的元素(例如见下文)。 目的
我想构建一个 C++ 可执行文件,以便所有库也附加到可执行文件。构建这样一个可执行文件的方法是什么?因此,每当我在其他 PC(运行 Ubuntu)上使用 g++ 编译我的代码时,它不需要运行该可执行文
我在 Netbeans IDE 8.0.1 中编写了一个名为 SampleChat 的 Java GUI 程序,并使用“clean and build”功能创建了一个 jar 文件。 我进入 Netb
我有两个 DLL,一个用 native C++ 编写,另一个用 C++/CLI 编写。前者被注入(inject)到进程中,并在稍后的时间点加载后者。在调试时,我注意到 native DLL 的断点运行
如何访问可执行文件的机器代码(二进制文件)? 详情 我使用的是 Ubuntu (Linux) 我想访问 .exe 文件(文件遵循 PE 格式)的机器代码(二进制文件) 我正在使用 C 来实现 最佳答案
这个问题在这里已经有了答案: Run java jar file on a server as background process (4 个回答) 关闭1年前. 我正在使用命令提示符运行一个可执行
我的 jar 没有运行,我可以告诉它尝试运行,因为 log4j 文件设法创建日志文件夹,但没有任何 react 并且日志为空白。 我的问题是我在名为 bin 的文件夹中有 jar 文件,在名为 lib
我正在为我教育第一学期的编程考试创建一个程序。它应该向用户显示哥本哈根和其他 6 个城市(在其他时区)的时间。用户还应该能够将城市添加到列表中。我正在用 JAVA 编写程序(下面提供源代码)。当我从
我正在查看雅虎的 YUI 压缩器可执行 jar,他们有这个类,从 list 文件链接为“主类”: package com.yahoo.platform.yui.compressor; import j
问题是:从 Eclipse 导出时可执行 jar 中包含什么?我问这个问题是因为我想知道,例如,如果我在项目根目录中有一个图像,该图像是否会包含在导出中? 澄清:我说的是可运行的 jar 文件(已编辑
我知道这个问题已经被问了很多,并且我已经尝试了 eclipse(Kepler、Ganymede、Galileo)、fatJar、netbeans、blueJ、命令行和手册中的大约 20-30 种不同的
我从 IntelliJ 14.03 中的一个工件构建了一个 .jar。当我尝试在 JRE 中打开它时,没有任何反应。这只是一个简单的 GUI。 提前致谢。 最佳答案 在jar位置运行命令,例如 jav
我使用 eclipse 创建了一个可执行 JAR 文件。我在项目文件夹中有资源当框架打开时不会出现。我的意思是当我双击 JAR 文件时。更多的所以,在我尝试删除 JAR 文件后,我收到一条警告,表明该
我创建了一个尺寸相当大(125,000 kb)的可运行 Jar 文件。当我运行它时,该 jar 文件内的应用程序不会显示,但在任务管理器中 javaw.exe(应链接到该 jar 文件)进程正在运行。
我已经使用 Eclipse(文件->导出)为我的 java 程序创建了一个可执行 jar 文件。 当我双击 jar 时,它工作正常。将 jar 文件复制到另一台计算机(Windows)后,我收到错误“
我用 eclipse indigo 创建了一个可执行的 jar 文件,但是当我双击它时什么也没有发生。但是当我将 java -jar c:/dir/filename.jar 写入 cmd 时,它可以工
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭10 年前。 Improve th
如何让该 Java 代码在 Eclipse 之外运行? import java.util.*; public class Calculations { public static void main(
今天我第一次启动 jar 文件时遇到问题。现在我知道(解压 jar 后)当我在 Eclipse 中导出并创建程序的 jar 包时,文本文件并没有出现。 为什么文本文件没有与类文件一起出现?我应该将它们
我不知道为什么,但是当我将项目导出到可执行 jar 文件时,有些东西并不像从 eclipse 运行程序一样。一帧不会打开,其中只包含文本。我有另一个内部框架,它是一个分割 Pane ,包含右侧面板上的
我是一名优秀的程序员,十分优秀!