4

認証に指紋を使用できるアプリがあります。

ユーザーが有効にするかどうかを尋ねる前に、それが利用可能かどうかを確認します。

FingerprintManager fingerprintManager = context.getSystemService(FingerprintManager.class);
return fingerprintManager.isHardwareDetected() && fingerprintManager.hasEnrolledFingerprints();

FingerprintManagerの両方のメソッドには、次の注釈が付けられています。

@RequiresPermission(USE_FINGERPRINT)

ただし、 http://developer.android.com/guide/topics/security/normal-permissions.htmlで指定されているように、USE_FINGERPRINT パーミッションは通常のものです。つまり、 AndroidManifest.xmlファイルでその権限を宣言すると(機能はテスト済みで、テスト デバイスで動作しています)、実行時に確認する必要はありません。

Fabric のクラッシュ レポートで報告されているように、現在起こっていることは、何人かのユーザーが次のように、fingerprintManager.isHardwareDetected()呼び出しでクラッシュしていることです。

java.lang.SecurityException: Must have android.permission.USE_FINGERPRINT permission.: Neither user 10150 nor current process has android.permission.USE_FINGERPRINT.

これまでのところ、Marshmallow (Android 6.0) の 2 人のユーザーで発生しており、どちらもルート化されておらず (Fabric による報告)、デバイスは LG G4 Stylus (LG H635) と Sony Xperia Z5 Premium (Sony E6853) です。

これがどのように可能になるかについての説明と、それに対する可能な修正はありますか?

これらのユーザーが通常の Android を使用していない場合、CyanogenMod のプライバシー ガードなどのカスタム ROM 機能を介してアプリのアクセス許可を操作できると言えます。しかし、そうではないようです。

スタック トレースは次のとおりです。

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)
4

3 に答える 3

0

問題は「自動的に」発生しなくなりました。

これまでのところ、影響を受けた 2 人のユーザーはそれぞれ別のバージョンのアプリ (2 週間ごとに公開) でしか確認できず、指紋のアクセス許可に関してアプリに変更はありませんでした。

クラッシュの最後の発生は3月17日でした。

これは、Android/Play ストアのアクセス許可の不具合だと思います。

于 2016-04-13T10:03:53.043 に答える