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.java
here
增加了额外的安全性在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");
}
任何想法如何修复此问题?如果你有类似的问题如何解决这个问题,请咨询。谢谢!