当前位置: 首页 > 编程笔记 >

Android获取超级管理员权限的实现

谭新知
2023-03-14
本文向大家介绍Android获取超级管理员权限的实现,包括了Android获取超级管理员权限的实现的使用技巧和注意事项,需要的朋友参考一下

1.定义特殊的广播接收者,系统超级管理员的广播接收者

public class MyDeviceAdminReceiver extends DeviceAdminReceiver{
 @Override
 public void onReceive(Context context,Intent intent){
  //TODO
 }
}

2.在AndroidManifest.xml文件中,注册超级管理员的广播接收者

<receiver
 android:name="com.example.receiver.MyDeviceAdminReceiver"
 android:permission="android.permission.BIND_DEVICE_ADMIN">
 <meta-data
  android:name="android.app.device_admin"
  android:resource="@xml/device_admin_sample"/>
 <intent-filter>
  <action android:name="android.app.action.DEVICE_ADMIN_ENABLED"/>
 </intent-filter>
</receiver>

3.在res/xml中创建策略声明xml

<device-admin xmlns:android="http://schemas.android.com/apk/res/android">
<uses-policies>
 <force-lock/><!--强制锁屏-->
 <wipe-data/><!--清除数据-->
 <reset-password/><!--重置密码-->
 ...
</uses-policies>

补充知识:Android通过代码获取ROOT权限

获取Android的ROOT权限其实很简单,只要在Runtime下执行命令"su"就可以了。

首先我们需要检测是否已经有root权限,判断代码如下:

// 判断是否具有ROOT权限
public static boolean is_root(){
 boolean res = false;
 try{ 
  if ((!new File("/system/bin/su").exists()) && 
   (!new File("/system/xbin/su").exists())){
  res = false;
 } 
 else {
  res = true;
 };
 } 
 catch (Exception e) { 
 
 } 
 return res;
}

然后我们执行获取root权限的代码

// 获取ROOT权限
public void get_root(){
 if (is_root()){
  Toast.makeText(mCtx, "已经具有ROOT权限!", Toast.LENGTH_LONG).show();
 }
 else{
  try{
   progress_dialog = ProgressDialog.show(mCtx, 
     "ROOT", "正在获取ROOT权限...", true, false);
   Runtime.getRuntime().exec("su");
  }
  catch (Exception e){
   Toast.makeText(mCtx, "获取ROOT权限时出错!", Toast.LENGTH_LONG).show();
  }
 }

}

以上这篇Android获取超级管理员权限的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。

 类似资料:
  • 除了为每一个用户设置权限,权限管理员 为连接及其数据库对象的权限提供另一查看方式。注意:只限于 MySQL、Oracle、PostgreSQL、SQL Server 和 MariaDB。 从用户的对象列表工具栏点击 权限管理员 并按照下列步骤进行: 在查看树展开节点直至到达目标对象。 选择对象并点击 添加权限 以打开窗口。 勾选用户以显示网格在右边的面板上。 在网格里,对照在 权限 列出的权限,勾

  • 除了在每个用户中设置权限,“权限管理员”提供另一种方式查看连接和其数据库对象的权限。 【注意】仅适用于 MySQL、Oracle、PostgreSQL、SQL Server、MariaDB 和 MongoDB。 若要添加权限,请在用户对象工具栏点击“权限管理员”并按照下列步骤: 在树视图展开节点直至到达目标对象。 选择对象并点击 “添加权限”以打开窗口。 在左侧窗格勾选用户。 在网格中,对照在“权

  • 除了在每个用户中设置权限,“权限管理员”提供另一种方式查看连接和其数据库对象的权限。 【注意】仅适用于 MySQL、Oracle、PostgreSQL、SQL Server、MariaDB 和 MongoDB。 若要添加权限,请在用户对象工具栏点击 并按照下列步骤: 在树视图展开节点直至到达目标对象。 选择对象并点击 以打开窗口。 在左侧窗格勾选用户。 在网格中,对照在“权限”列出的权限,勾选相关

  • 除了在每个用户中设置权限,“权限管理员”提供另一种方式查看连接和其数据库对象的权限。 【注意】仅适用于 MySQL、Oracle、PostgreSQL、SQL Server、MariaDB 和 MongoDB。 若要添加权限,请在用户对象工具栏点击“权限管理员”并按照下列步骤: 在树视图展开节点直至到达目标对象。 选择对象并点击 “添加权限”以打开窗口。 在左侧窗格勾选用户。 在网格中,对照在“权

  • 超级管理员是整个系统的管理员。我们可以在RBAC,ABAC以及带域的RBAC等模型中使用它 具体例子如下: [request_definition] r = sub, obj, act [policy_definition] p = sub, obj, act [policy_effect] e = some(where (p.eft == allow)) [matchers] m = r.

  • 本文向大家介绍Android获取设备隐私 忽略6.0权限管理,包括了Android获取设备隐私 忽略6.0权限管理的使用技巧和注意事项,需要的朋友参考一下 一.前言 (1).由于MIUI等部分国产定制系统也有权限管理,没有相关api,故无法判断用户是否允许获取联系人等隐私。在Android 6.0之后,新增权限管理可以通过官方api判断用户的运行状态; (2).我们指定targetSdkVersi