安卓开发的程序怎么获取权限
⑴ 如何使android应用程序获取system权限
不论何种系统版本,均需要root权限。
安卓4.4以下版本的方法:
使用re管理器移动想要获取system权限的软件的apk安装包到/system/app文件夹,更改权限为rw-r-r确定后重启手机。
安卓4.4和以上版本的方法:
使用re管理器移动想要获取system权限的软件的apk安装包到/system/priv-app文件夹,更改权限为rw-r-r确定后重启手机。
备注:安卓系统并不像windows,system权限(uid1000)并不是最高权限,仅仅比普通用户拥有少量的特殊权限,比如安装软件无需弹窗。而系统中最高权限是root权限(uid0)。
⑵ 安卓怎么让软件获得最高权限
1. 将要执行的命令写成脚本,或者可执行程序。
下面是脚本 ifconfig_test.sh :
# ! /system/bin/sh
ifconfig
注意: 脚本的第一行必须为 # ! /system/bin/sh ,否则无法执行,通过 dmesg 可以查看到信息内容为 cannot execve ./ifconfig_test.sh: Exec format error
也可以采用 C/C++ 编写需要执行的命令或者程序,并在编译 image 的时候编译成可执行程序。
2. 在 init.rc 中注册 service
Android 中的 service 需要在 init.rc 中注册, Init.rc 中定义的 Service 将会被 init 进程创建,这样将可以获得 root 权限。当得到相应的通知(通过属性设置)后, init 进程会启动该 service 。
本文中注册的内容如下:
service ifconfig_test /system/etc/ifconfig_test.sh
oneshot
disabled
其中, oneshot 表示程序退出后不再重新启动, disabled 表示不在系统启动时启动。
注意: 这里 service name 不能超过 16 个字符。我之前的 service name 由于定义的比较长, 18 个字符,设置属性通知 service 启动后查看 dmesg 可以看到提示: init: no such service 。查看 /system/core/init/parser.c 的源代码,在 parse_service->valid_name 函数中可以看到如下内容: if (strlen(name) > 16) { return 0; } ,证明 service 的名字的确不能超过 16 个字符。3. 将 Android 应用程序提升为 system 权限
既然应用程序可以通过启动 service 获得 root 权限,那么岂不是很不安全。 Android 考虑到了这点,规定只有 system 权限的应用程序才能设置属性,通知 service 启动。关于提升 system 权限的文章网上已有很多,这里就不再细说
4. 在应用程序中添加属性设置代码
前面已经提到,对于 Android 来说,应用程序通知 init 启动 service 是通过设置系统属性来完成的,具体为设置 System 系统属性 “ctl.start” 为 “ifconfig_test” ,这样 Android 系统将会帮我们运行 ifconfig_test 这个 service 了。
对该系统属性的设置有三种方法,分别对应三种不同的应用程序:
1) Java 代码
Android 在 Java 库中提供 System.getProperty 和 System.setProperty 方法, Java 程序可以通过他们来设置和获得属性。代码如下:
SystemProperties.set("ctl.start", "ifconfig_test");
上面的代码是通知 Android 执行 ifconfig_test service ,如果需要查询当前 service 执行的状态,如是否执行完毕,可以通过如下代码查询:
ret = SystemProperties.get("init.svc. ifconfig_test ", "");
if(ret != null && ret.equals("stopped"))
{
return true;
}
2) JNI 代码
当编写 NDK 的程序时,可以使用 property_get 和 property_set 这两个 API 来获得和设置属性。使用这两个 API 必须要包含头文件 cutils/properties.h 和链接 libcutil 库。
3) Shell 脚本
Android 提供了命令行 setprop 和 getprop 来设置和获取属性,他们可以在脚本中被使用。
由于我的程序是在 JNI 中调用脚本,脚本中又执行 ifconfig ,因此我将设置属性的部分放在了脚本中完成,代码如下:
setprop ctl.start ifconfig_test
#wait for the service until it stops
ret=1
while [ $ret -ne 0 ]
do
getprop | grep "$ENABLE_MAPPER_SRV" | grep stopped
ret=$?
done
通过上面 4 个步骤, Android 应用程序就获得了 root 权限,更具体的说,是在执行需要执行的命令时临时获得了 root 权限。
⑶ Android应用程序怎样获取读取系统文件的权限
Android应用程序怎样获取读取系统文件的权限
1、必须是Android系统开发人员,否则你无法修改init.rc等文件。 2、你的应用程序必须要获得system权限。
在应用层 你要想用代码获得系统文件权限,除非你手机root了
要么你自己坐rom。。。。 自己修改 init,rc
具体可以参考这篇博文::blog.sina../s/blog_5f35912f0100w4ld.
怎样使Android应用程序获得root权限
可以参考如下内容:
按照 Simon 的文章中提到的,应用程序有以下两种办法临时获得 root 权限:
1) 实现一个 init 实现一个 Service ,来帮助 Android 应用程序执行 root 权限的命令。
2) 实现一个虚拟设备,这个设备帮助 Android 应用程序执行 root 权限的命令。
第二种办法我这里没有尝试,暂时也不会。这里讲讲我在实现第一种办法做扰物的过程和遇到的一些问题。
1. 将我们要执行的命令写成脚本,或者可执行程序。
下面是我的脚本 ifconfig_test.sh :
# ! /system/bin/sh
ifconfig
注意: 脚本的第一行必须为 # ! /system/bin/sh ,否则无法执行,通过 dmesg 可以查看到信息内容为cannot execve ./ifconfig_test.sh: Exec format error
android应用程序获取了root权限,依然不能访问系统data目录下的文件
- Root后授权Re文件管理器权限可以访问。
-
授权管理----允许Re获取权限。
-
Root是获取手机的管理员用户帐户,它可以访问和修改手机操作系统里几乎所有的文件,这样操作有可能影响到手机的稳定性,导致出现人为性故障现象,如死机、重启等。依据“消费者三包规定”Root属于修改操作系统软件,不属于包修范围李轿。
android应用程序如何获取View的坐标
public boolean onTouchEvent(android.view.MotionEvent event) { int x = event.getX(); int y = event.getY(); 多点触摸时 假如是第i个点 int x = event.getX(i); int y = event.getY(i); 坐标就是 P(x,y) }
如何使Android应用程序获得root权限
下载并安装好腾讯手机管家PC版之后,打开该软件并进入工具箱,你会发现“一键ROOT”和“KingRoot”两款工具。通过USB 将手机同电脑连接后,无论选择那纯液款工具,用户都可以通过简单的鼠标点击,完成之前难以达成的任务。选择“一键ROOT”按钮后,应用工具将智能匹配手机系统,寻找最适合该手机的ROOT方案,几分钟之后,用户手机即可成功获得ROOT权限。
Android应用程序获得root权限
在获取root权限后可以批量卸载系统自带应用
并且可以批量备份,在卸载系统应用之前先备份一次
然后就可以安心卸载系统自带应用了,
我一直是在用应用宝的手机管理软件在工具
箱的常用工具中找到一键ROOT工具,
点击启动该工具便可以轻松的实现手机一键ROOT。
此外,你还可以点击一键优化按钮来优化
手机建议一键优化,选择您需要的单个优化项,如垃圾缓存清理。
你可以尝试安装Kingroot授权管理软件,或者安装一键root大师软件进行root操作,只要你尝试root操作,一定可以root成功的。
Root权限的获取方式: 1.用手机连接电脑,下载一键root工具。 2.下载成功后,打开一键ROOT软件。会出现root准备,点击下一步,正式开始root。 3.检查root条件,要是需要文件备份的话,一定要备份后。点击开始ROOT。 4.root正式开始,需要几钟左右时间,期间可能会重启数次,root就会完成。 5.root完成后,就可以随意删除手机中的垃圾应用了包括系统应用。
Android system 要获取Root权限, 方法众多。
例如 : Bai Root, Amazing Root ...都可以
现以 BAIDU ROOT介绍步骤, 操作如下 :
1、机子下载 BAIDU ROOT(APK版)。
2、运作 BAIDU ROOT, 点选 "一键获取Root"。
3、机子 Root 成功了, 自动重启 。
PS:建议Rooting前备份手机数据。 Rooting过程约需时5min。
你可以试试刷机精灵,蘑菇云,深度刷机,Z4ROOT,甜椒等等,,,注意ROOT后,必须安装SUPERUSER,用于权限的管理,否则将没有任何作用,,,其实手机端也有很多,你可以到安卓软件站搜索ROOT,下载并安装,进行ROOT破解即可,,,不过解决方法会少很多,最好是电脑端ROOT破解。。。。刷机工具,可以到XIAZAIBA下载、。、
⑷ 安卓开发我想获取System权限
System权限需要先获取ROOT权限,由于 /system 和 /data都是root用户的目录,普通用户没有读写权限,需要获取root权限才可以,修改。
目前应用市场有非常多的一键ROOT工具,这里就不举例了,功能基本都是一样的,Root权限的获取方式:
1.用手机连接电脑,下载一键root工具。
2.下载成功后,打开一键ROOT软件。会出现root准备,点击下一步,正式开始root。
3.检查root条件,要是需要文件备份的话,一定要备份后。点击开始ROOT。
4.root正式开始,需要几钟左右时间,期间可能会重启数次,root就会完成。
5.root完成后,就可以随意删除手机中的垃圾应用了包括系统应用。
当你获取root权限后通过adb访问 /system/app目录:
adb shell 进入shell模式
su 切换到root用户
chmod 777/system/app修改/system/app目录的权限为 777即可
exit 退出root用户
cd/system/app即可进入/system/app目录了
获取root权限后,将apk复制到/system/app目录下即可。