Android 判断root权限的三种方法

 

 /**
 */
public class Root {

    private static String LOG_TAG = Root.class.getName();

    public boolean isDeviceRooted() {
        if (checkRootMethod1()){return true;}
        if (checkRootMethod2()){return true;}
        if (checkRootMethod3()){return true;}
        return false;
    }

    public boolean checkRootMethod1(){
        String buildTags = android.os.Build.TAGS;

        if (buildTags != null && buildTags.contains("test-keys")) {
            return true;
        }
        return false;
    }

    public boolean checkRootMethod2(){
        try {
            File file = new File("/system/app/Superuser.apk");
            if (file.exists()) {
                return true;
            }
        } catch (Exception e) { }

        return false;
    }

    public boolean checkRootMethod3() {
        if (new ExecShell().executeCommand(SHELL_CMD.check_su_binary) != null){
            return true;
        }else{
            return false;
        }
    }
}


/**
 * @author Kevin Kowalewski
 *
 */
public class ExecShell {

    private static String LOG_TAG = ExecShell.class.getName();

    public static enum SHELL_CMD {
        check_su_binary(new String[] {"/system/xbin/which","su"}),
        ;

        String[] command;

        SHELL_CMD(String[] command){
            this.command = command;
        }
    }

    public ArrayList<String> executeCommand(SHELL_CMD shellCmd){
        String line = null;
        ArrayList<String> fullResponse = new ArrayList<String>();
        Process localProcess = null;

        try {
            localProcess = Runtime.getRuntime().exec(shellCmd.command);
        } catch (Exception e) {
            return null;
            //e.printStackTrace();
        }

        BufferedWriter out = new BufferedWriter(new OutputStreamWriter(localProcess.getOutputStream()));
        BufferedReader in = new BufferedReader(new InputStreamReader(localProcess.getInputStream()));

        try {
            while ((line = in.readLine()) != null) {
                Log.d(LOG_TAG, "--> Line received: " + line);
                fullResponse.add(line);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

        Log.d(LOG_TAG, "--> Full response was: " + fullResponse);

        return fullResponse;
    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android开发中的su权限是指在Android设备上运行的应用程序获取超级用户权限(即root权限)的能力。 在Android系统中,su(superuser)命令是一种特殊的命令,可以让普通用户以超级用户身份执行特权操作。su权限可以让应用程序获得系统的完全控制权,可以访问和修改系统的一切文件和设置。 在Android开发中,如果需要使用su权限,可以通过使用Root权限管理器来实现。Root权限管理器是一种在root权限下运行的应用程序,它可以管理应用程序的root权限的获取和使用。 要在应用程序中获取su权限,首先需要判断设备是否已经获取了root权限。可以通过检查系统的/system/bin/su文件是否存在来确定设备是否已经root。 如果设备已经root,可以使用Java的Runtime类中的exec()方法来运行shell命令,并在命令前加上su命令来获取超级用户权限: ``` Process process = Runtime.getRuntime().exec("su"); ``` 通过这种方式,就可以在应用程序中获取su权限,并在shell命令中执行需要超级用户权限的操作。 需要注意的是,对于非root设备,应用程序是无法直接获取su权限的。这是因为Android系统出于安全考虑,在非root设备上禁止了普通应用程序获得超级用户权限。 总之,su权限是Android开发中一种获取超级用户权限的能力,但需要注意的是,获取su权限需要在已经root的设备上进行,并且在应用程序中使用su权限时应谨慎操作,避免对系统造成损坏。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值