2014-11-24 19 views
5

Wydaje się niektóre funkcje DeviceAdmin zostało złamane w Lollipop, przynajmniej na moim Nexus 5.DevicePolicyManger(). GetCurrentFailedPasswordAttempts wywala aplikacja

Działa to doskonale na KitKat, Jellybean i Ice Cream Sandwich

@Override 
public void onPasswordFailed(Context context, Intent intent) { 

    DevicePolicyManager policyManager = (DevicePolicyManager)context.getSystemService(Context.DEVICE_POLICY_SERVICE); 
    if(policyManager != null){ 
     int attempts = policyManager.getCurrentFailedPasswordAttempts(); 
     Log.v("TAG", "Attempts = " + attempts); 
    } 
} 

Ale na moim Nexusie 5 z Androidem 5.0 Lollipop produkuje następujący błąd:

11-24 16:11:50.117 27053-27053/com.example.myapp E/AndroidRuntime﹕ FATAL EXCEPTION: main 
    Process: com.example.myapp, PID: 27053 
    java.lang.RuntimeException: Unable to start receiver com.example.myapp.receivers.AdminReceiver: java.lang.NullPointerException: Attempt to read from field 'int android.content.pm.UserInfo.id' on a null object reference 
      at android.app.ActivityThread.handleReceiver(ActivityThread.java:2586) 
      at android.app.ActivityThread.access$1700(ActivityThread.java:144) 
      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1355) 
      at android.os.Handler.dispatchMessage(Handler.java:102) 
      at android.os.Looper.loop(Looper.java:135) 
      at android.app.ActivityThread.main(ActivityThread.java:5221) 
      at java.lang.reflect.Method.invoke(Native Method) 
      at java.lang.reflect.Method.invoke(Method.java:372) 
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) 
    Caused by: java.lang.NullPointerException: Attempt to read from field 'int android.content.pm.UserInfo.id' on a null object reference 
      at android.os.Parcel.readException(Parcel.java:1546) 
      at android.os.Parcel.readException(Parcel.java:1493) 
      at android.app.admin.IDevicePolicyManager$Stub$Proxy.getCurrentFailedPasswordAttempts(IDevicePolicyManager.java:2476) 
      at android.app.admin.DevicePolicyManager.getCurrentFailedPasswordAttempts(DevicePolicyManager.java:1261) 
      at com.example.myapp.receivers.AdminReceiver.onPasswordFailed(AdminReceiver.java:48) 
      at android.app.admin.DeviceAdminReceiver.onReceive(DeviceAdminReceiver.java:417) 
      at android.app.ActivityThread.handleReceiver(ActivityThread.java:2579) 
            at android.app.ActivityThread.access$1700(ActivityThread.java:144) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1355) 
            at android.os.Handler.dispatchMessage(Handler.java:102) 
            at android.os.Looper.loop(Looper.java:135) 
            at android.app.ActivityThread.main(ActivityThread.java:5221) 
            at java.lang.reflect.Method.invoke(Native Method) 
            at java.lang.reflect.Method.invoke(Method.java:372) 
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) 

It's been reported as an issue in the L-preview as well.

Moje pytanie, co to powoduje?

+0

FYI: Moja aplikacja ma ten sam problem, więc nie jesteś sam. "Rozwiązałem" go za pomocą prostego bloku catch catch - przynajmniej aplikacja przestanie działać. –

+0

Dzięki @TheisBorg - Na razie zachowam statyczne odwołanie do prób odblokowania, dopóki bohater nie przyjdzie i nie zapisze dnia. – Jakob

Odpowiedz

0

Mam ten sam błąd, wtedy zdałem sobie sprawę, że może nie działać dla wersji 5.0 i wyżej.Tak co zrobiłem to sprawdzam liczbę błędnych prób programowo.Jeśli ktoś chce odblokować wzór lub pin jeśli wprowadzi on błąd, wówczas odbiorca złapie i wywoła metodę passwordFailed(). Tak więc utworzyłem obiekt SharedPreference i zapisuję numer metody passwordFailed(). Na podstawie tego otrzymuję liczbę niewłaściwych wzorów. Myślę, że to jest poprawny sposób, czy nie, nie wiem.

Powiązane problemy