能力值:
( LV2,RANK:10 )
|
-
-
2 楼
可以使用部分指令吧,用Runtime的exec...
|
能力值:
( LV2,RANK:10 )
|
-
-
3 楼
我是在jni层,用linux的popen函数实现的,简单的命令都可以,就只有insmod不行,不知道为什么。。
|
能力值:
( LV2,RANK:10 )
|
-
-
4 楼
试了java层Runtime的exec,也不行,郁闷。。。
|
能力值:
( LV7,RANK:100 )
|
-
-
5 楼
java层。 java.lang.Runtime's exec() methods:
http://developer.android.com/reference/java/lang/Runtime.html
native层就是jni了。可以用popen() 。但指令知否支持就得看bionic了。也可以尝试
system() and pipe。
|
能力值:
( LV3,RANK:20 )
|
-
-
6 楼
普通apk不可能有root权限,除非机器被root了,使用Runtime.exec之类的执行su -c insmod xx.ko
su为root的象征,配合superuser使用
|
能力值:
( LV2,RANK:10 )
|
-
-
7 楼
system() 也试了,还是不行。
|
能力值:
( LV2,RANK:10 )
|
-
-
8 楼
我的模拟器root了,试了多种方法都不行,现在只能命令行加载了。。
|
能力值:
( LV2,RANK:10 )
|
-
-
9 楼
init.rc试试
|
能力值:
( LV3,RANK:20 )
|
-
-
10 楼
厉害啊, 我还不知道怎样为手机编译内核模块呢。求指教阿
|
能力值:
( LV2,RANK:10 )
|
-
-
11 楼
在终端下使用su进入root用户,然后insmod xx.ko这个肯定可以成功的,因为insmod在root用户下执行的。但是Java的Runtime.exec()也好,Native层execl()也好,只能用su -c命令临时在root用户下执行一条指令。
adb shell进入终端,普通用户下执行su -c insmod xx.ko,会发现命令执行失败,失败原因就是需要注意的地方,su的-c参数只把下一个变量作为可执行的指令,因此其执行的命令是insmod而参数并没有传递过去,xx.ko作为了su的参数,因此如果想执行成功我们需要使用su -c "insmod xx.ko",将传递给insmod的参数和命令组合成一个参数。
这样的话在Java层和Native层执行失败的问题也可以解决了,在Runtime.exec()中将命令格式进行格式化,比如Runtime.exec(“su -c ” + "\"insmod xx.ko\"" ),或者在Native中执行execl("/sytem/bin/su","/sytem/bin/su","-c","insmod xx.ko", NULL),这样最终传递给shell的命令就是su -c "insmod xx.ko"了。
|
|
|