2013-02-26 78 views
1

我正在研究与安全性有关的应用程序。即使用户将设备重置为出厂设置,也不能删除应用程序。要做到这一点,设备必须扎根。然而,当我试图获得该位置作为root用户我得到这个错误在Android Jellybean (4.1.1)当应用程序以超级用户身份运行时,GPS不工作

uncaughtException # Exception found!! 
java.lang.SecurityException: invalid UID 0 
at android.os.Parcel.readException(Parcel.java:1379) 
at android.location.ILocationManager$Stub$Proxy.requestLocationUpdates(ILocationManager.java:659) 
at android.location.LocationManager._requestLocationUpdates(LocationManager.java:664) 
at android.location.LocationManager.requestLocationUpdates(LocationManager.java:486) 

当我看着Android源代码,我看到谷歌已经在LocationManagerService.javahere

增加了额外的安全性在requestLocationUpdates函数调用

checkPackageName(Binder.getCallingUid(), packageName); 

这是checkPackageName功能

private void checkPackageName(int uid, String packageName) { 
    if (packageName == null) { 
     throw new SecurityException("packageName cannot be null"); 
    } 
    String[] packages = mPackageManager.getPackagesForUid(uid); 
    if (packages == null) { 
     throw new SecurityException("invalid UID " + uid); 
    } 
    for (String pkg : packages) { 
     if (packageName.equals(pkg)) return; 
    } 
    throw new SecurityException("invalid package name"); 

}

任何想法如何修复此问题?如果你有类似的问题如何解决这个问题,请咨询。谢谢!

回答

0

之前打电话给位置服务:

final long ident = Binder.clearCallingIdentity(); 

调用后:

Binder.restoreCallingIdentity(ident); 
相关问题