3

我有一个 .so 文件,我将其打包到 obb 扩展中。它大约是 20 兆字节。

我正在尝试使用

System.load("/storage/emulated/0/Android/obb/com.mypackage.myapp/libtest.so");

加载库。但我得到了错误:

dlopen(“/storage/emulated/0/Android/obb/com.mypackage.myapp/libtest.so”,RTLD_LAZY)失败:dlopen 失败:无法映射“/storage/emulated/0/Android/obb/com. mypackage.myapp/libtest.so”段 2:权限被拒绝

type=1400 audit(0.0:8):avc: denied { execute } for path="/storage/emulated/0/Android/obb/com.mypackage.myapp/libtest.so" dev="fuse" ino=367663176224 scontext =u:r:untrusted_app:s0 tcontext=u:object_r:fuse:s0 tclass=文件许可=0

所以我意识到我们不允许在那里有可执行文件。

所以我的问题是,

1-应该在哪里提取文件才能做到这一点?

2-我应该调用什么函数?

谢谢你。

4

1 回答 1

3

将文件复制到应用程序的私有内部存储文件夹下您选择的任何位置,确保它被标记为只读和可执行(不可写,尤其是其他任何人!)。这是允许可执行文件的应用程序通常可写的唯一位置树。

getFilesDir()您可以通过调用已初始化的 Activity 或 Service Context来确定私有文件夹的位置。

这里有许多现有的问题演示了 Java 中的文件复制机制。

于 2015-05-14T15:24:49.223 回答