如今Android手機root權限能夠說是輕鬆就獲取獲得的,而關於判斷手機是否已經root的方法,你瞭解嗎?若是app有一些特殊功能須要root權限,則須要判斷是否root。不知道root是否是意味着手機不安全?說到底仍是想一臺究竟,你能夠學習Android應用開發視頻教程。下面介紹兩種方法:android
方法1:shell
/**
* @author Kevin Kowalewski
*
*/
public class Root {安全private static String LOG_TAG = Root.class.getName();app
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;uiif (buildTags != null && buildTags.contains(「test-keys」)) {
return true;
}
return false;
}thispublic boolean checkRootMethod2(){
try {
File file = new File(「/system/app/Superuser.apk」);
if (file.exists()) {
return true;
}
} catch (Exception e) { }googlereturn false;code
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;
}
}
代碼來自stackoverflow,向做者致敬。
方法2:
The RootTools library offers simple methods to check for root:
一個開源項目:http://code.google.com/p/roottools/
RootTools.isRootAvailable()判斷是否root
RootTools.isAccessGiven()返回true那麼手機已經root而且app也被授予root權限。
String commandToExecute = 「su」;
executeShellCommand(commandToExecute);
private boolean executeShellCommand(String command){
Process process = null;
try{
process = Runtime.getRuntime().exec(command);
return true;
} catch (Exception e) {
return false;
} finally{
if(process != null){
try{
process.destroy();
}catch (Exception e) {
}
}
}
}
ps:使用這些方法有可能將手機系統拖的很是慢,當應用屢次啓動後會建立出不少個僵死的進程耗用內存。
還有更多移動互聯網教程資訊等請關注e良師益友網。