我有一个应用程序,可以使用指纹进行身份验证。
在询问用户是否要启用它之前,我会验证它是否可用,并且通过以下方式完成:
FingerprintManager fingerprintManager = context.getSystemService(FingerprintManager.class);
return fingerprintManager.isHardwareDetected() && fingerprintManager.hasEnrolledFingerprints();
FingerprintManager的两种方法都带有注释:
@RequiresPermission(USE_FINGERPRINT)
但是,USE_FINGERPRINT权限是正常的权限,如 http://developer.android.com/guide/topics/security/normal-permissions.html 中所述。这意味着,一旦您在 AndroidManifest.xml 文件中声明了该权限(我们这样做,该功能已经过测试并在测试设备上运行),您就不必在运行时检查它。
正如Fabric崩溃报告所报告的那样,现在发生的事情是一些用户在fingerprintManager.isHardwareDetect()调用中崩溃:
java.lang.SecurityException: Must have android.permission.USE_FINGERPRINT permission.: Neither user 10150 nor current process has android.permission.USE_FINGERPRINT.
到目前为止,已经有2个用户发生了这种情况,都是在棉花糖(Android 6.0)上,他们都没有扎根(据Fabric报道),设备是LG G4 Stylus(LG H635)和Sony Xperia Z5 Premium(Sony E6853)。
关于这如何可能以及可能的解决方法的任何解释?
如果这些用户不是使用普通Android,我会说他们能够通过自定义ROM功能(如CyanogenMod的Privacy Guard)操纵应用程序权限。但事实似乎并非如此。
堆栈跟踪为:
Fatal Exception: java.lang.RuntimeException: Unable to start activity ComponentInfo{MY.PACKAGE/MY.PACKAGE.MYACTIVITY}: java.lang.SecurityException: Must have android.permission.USE_FINGERPRINT permission.: Neither user 10150 nor current process has android.permission.USE_FINGERPRINT.
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2434)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2494)
at android.app.ActivityThread.access$900(ActivityThread.java:157)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1356)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5527)
at java.lang.reflect.Method.invoke(Method.java)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:730)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
Caused by java.lang.SecurityException: Must have android.permission.USE_FINGERPRINT permission.: Neither user 10150 nor current process has android.permission.USE_FINGERPRINT.
at android.os.Parcel.readException(Parcel.java:1599)
at android.os.Parcel.readException(Parcel.java:1552)
at android.hardware.fingerprint.IFingerprintService$Stub$Proxy.isHardwareDetected(IFingerprintService.java:367)
at android.hardware.fingerprint.FingerprintManager.isHardwareDetected(FingerprintManager.java:642)
at MY.PACKAGE.MYACTIVITY.isSupported(MYACTIVITY.java:54)
at MY.PACKAGE.MYACTIVITY.onCreate(MYACTIVITY.java:38)
at android.app.Activity.performCreate(Activity.java:6272)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1108)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2387)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2494)
at android.app.ActivityThread.access$900(ActivityThread.java:157)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1356)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5527)
at java.lang.reflect.Method.invoke(Method.java)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:730)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
看起来像构建过程中的错误。清理/重建使问题消失
问题"自动"停止发生。
到目前为止,我只能看到这两个受影响的用户各自使用我们应用程序的不同版本(我们每 2 周发布一次),并且应用程序中在指纹权限方面没有任何变化。
最后一次发生坠机是在3月17日。
我认为这是Android/Play商店权限故障。
我通过从依赖项中删除构建库并从 Lollipins 的 github 源中添加"lib"目录来修复以下问题 https://github.com/omadahealth/LolliPin/tree/master/lib
- 从build.gradle中删除"implementation('com.github.omadahealth:lollipin:2......"
- 将"实现项目(':lib')"添加到build.gradle
- 将"include ':lib'"添加到您的设置中。
在您的 IDE(我正在使用 android Studio)上,导航到第 147 行AppLockActivity.java
: 更改为:
if (mFingerprintManager != null && mFingerprintManager.isHardwareDetected() && mFingerprintUiHelper.isFingerprintAuthAvailable())
FingerprintManager.isHardwareDetection() 抛出 java.lang.SecurityException,因为某些设备没有指纹硬件或禁用指纹。您可以按照以下传导操作以避免崩溃。
if(getSystemService(Context.FINGERPRINT_SERVICE) == null) {
notifyUser("Fingerprint hs not been enabled in settings.")
}
else {
Here you can place your fingerprint manager code
}