当前位置: 首页 > 面试题库 >

位置独立的可执行文件和Android

张亦
2023-03-14
问题内容

我已经编写了一个.c源代码(在Eclipse中),它使用libcap库来获取与网络流量有关的信息。现在,我已经在Eclipse中使用ndk-
build创建了一个可执行二进制文件。我已将在libs / armeabi文件夹中创建的二进制文件推送到我的android的/ data / local
/文件夹中(根目录为nexus 5,Lollipop),并尝试执行该二进制文件。但是android抛出此错误

错误:仅支持与位置无关的可执行文件(PIE)

我对PIE一无所知,请告诉我如何创建与位置无关的可执行文件。


问题答案:

我对PIE一无所知,请告诉我如何创建与位置无关的可执行文件。

位置独立可执行文件(PIE)允许程序重定位,就像共享对象一样。在程序的每次运行中,都可以将程序加载到不同的地址,从而使攻击者更难猜测某些程序状态。

您可以通过以下两种方式之一来编译和链接PIE可执行文件。首先,使用编译所有内容-fPIE并使用链接-pie。第二个是用编译所有内容并-fPIC与链接-pie

如果要同时构建共享库和程序,请使用编译所有内容-fPIC。用链接共享对象-shared,并用链接程序-pie

您无法以其他方式做到这一点。也就是说,您不能使用编译所有内容-fPIE并构建共享对象和程序。有关详细信息,请参见GCC手册中的代码生成选项。

在Android上需要注意的一件事:在4.1之前的版本中使用PIE构建将导致中的分段错误/system/bin/linker。PIE是在Android
4.1上添加的,它会使次要版本崩溃。

有人告诉我提供一个自定义链接/加载程序来避免此问题,但目前无法找到参考。

另请参阅Android
1.5至4.1中的安全性增强功能。

错误:仅支持与位置无关的可执行文件(PIE)

是的,这是棒棒糖功能。请参阅Android
5.0中的安全性增强。

您可以使用以下命令检查程序是否使用PIE构建readelf

$ readelf -l my-prog | grep -i "file type"
Elf filetype is DYN (shared object file)

重要的readelf是报告 DYN ,而不是报告 EXE
EXE表示它缺少PIE,并且应该触发与安全性相关的缺陷。



 类似资料:
  • 问题内容: 我了解到,使用exec()调用发出的命令的可执行文件应该存储在PATH变量一部分中的目录中。 因此,我在/ bin中找到的可执行文件。 但是,我找不到的可执行文件。 它在哪里? 问题答案: 进程只能影响其自己的工作目录。当可执行文件由外壳执行时,它将作为子进程执行,因此cd可执行文件(如果存在)将在不影响父进程(外壳)的情况下更改该子进程的工作目录,因此cd命令必须实现为内置的shel

  • 问题内容: 我想自动化一个相当简单的任务。为此,我编写了一个小的PHP脚本,该脚本使用PHP-CLI从命令行运行。现在,我想将此脚本移交给某人,但我不想: 放弃源代码 请他在系统上安装PHP 有没有一种方法可以创建PHP脚本的.exe版本。我真的不太担心反编译。我更担心要求人们安装和配置PHP。 问题答案: peachpie. http://www.peachpie.io https://gith

  • 我在htmlunitdriver.java文件中做了一个补丁,如下文所述:使用WebDriver(HtmlUnit,Ruby绑定)时是否可能忽略JavaScript异常 我已经学习了关于selenium build wiki和自述文件中的说明,以及这里给出的技巧:构建selenium服务器项目 但是,我没有一个像selenium-server-standalone-2.25.0.jar这样的jar

  • 我试图设置一个独立的Spark2.0服务器来并行处理分析功能。为此,我希望有一个带有多个执行者的工作人员。 我在使用: 独立Spark 2.0 8核 24gig ram Windows server 2008 pyspark(尽管这看起来不相关)

  • 我试图编译一个“su”超级用户实用程序的修改版本,所以我在git上访问了android5.0源代码,得到了“su.c”文件。 我的实际设备/硬件是一部运行以下功能的乐视x500手机: Android 5.0.2,SDK 21 CPU架构AArch64处理器版本2 指令集arm64-v8a 我是关于硬件数据,因为我已经检查了制造商的网站 使用cygwin shell: $sh制作独立的工具链。sh-

  • 问题内容: C / C ++中是否可以找到当前已执行程序的位置(完整路径)? (问题在于它没有给出完整的路径。) 问题答案: 总结一下: 在Unix上,真正可行的方法是: (Linux) (FreeBSD) (Solaris) 在没有Unix的Unix上(即,如果以上失败): 如果argv [0]以“ /”(绝对路径)开头,则为路径。 否则,如果argv [0]包含“ /”(相对路径),则将其附加