2017-06-02 82 views
2

最近我在使用React-Native应用程序时遇到了一个非常奇怪的问题。这里是我的environement:请求权限时引发React-Native(Android):ArrayIndexOutOfBoundsException

  • 矩形本地0.42.3
  • 三星Galaxy Note 5
  • 的Android 6.0

正如你可能知道,Android的权限模型自棉花糖改变,但一些几天前,我得到了他的例外:

java.lang.RuntimeException: 
    at android.app.ActivityThread.performResumeActivity(ActivityThread.java:4156) 
    at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:4250) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1839) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:158) 
    at android.app.ActivityThread.main(ActivityThread.java:7229) 
    at java.lang.reflect.Method.invoke(Native Method:0) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 
Caused by: java.lang.ArrayIndexOutOfBoundsException: 
    at com.facebook.react.modules.permissions.PermissionsModule$1.invoke(PermissionsModule.java:119) 
    at com.facebook.react.modules.permissions.PermissionsModule.onRequestPermissionsResult(PermissionsModule.java:207) 
    at com.facebook.react.ReactActivityDelegate$1.invoke(ReactActivityDelegate.java:211) 
    at com.facebook.react.ReactActivityDelegate.onResume(ReactActivityDelegate.java:131) 
    at com.facebook.react.ReactActivity.onResume(ReactActivity.java:66) 
    at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1286) 
    at android.app.Activity.performResume(Activity.java:6987) 
    at android.app.ActivityThread.performResumeActivity(ActivityThread.java:4145) 

首先,我以为我错过了在代码检查,如解释here但这并非如此,因为否则我会这样,而不是消息:

java.lang.SecurityException: Permission Denial: opening provider com.android.providers.contacts.ContactsProvider2 from ProcessRecord{fac49ea 4674:com.gospacesmobile/u0a65} (pid=4674, uid=10065) requires android.permission.READ_CONTACTS or android.permission.WRITE_CONTACTS 

我看着阵营本地的代码,发现这样的:

// com.facebook.react.modules.permissions.PermissionsModule.java 
int[] results = (int[]) args[0]; 
if (results[0] == PackageManager.PERMISSION_GRANTED) { // <- the exception happens when results is empty 
    promise.resolve(GRANTED); 
} else { 
    PermissionAwareActivity activity = (PermissionAwareActivity) args[1]; 
    if (activity.shouldShowRequestPermissionRationale(permission)) { 
     promise.resolve(DENIED); 
    } else { 
     promise.resolve(NEVER_ASK_AGAIN); 
    } 
} 

根据documentation的grantResults变量可能是空的,只要权限请求被取消:

@Override 
public void onRequestPermissionsResult(int requestCode, 
     String permissions[], int[] grantResults) { 
    switch (requestCode) { 
     case MY_PERMISSIONS_REQUEST_READ_CONTACTS: { 
      // If request is cancelled, the result arrays are empty. 
      if (grantResults.length > 0 
       && grantResults[0] == PackageManager.PERMISSION_GRANTED) { 

       // permission was granted, yay! Do the 
       // contacts-related task you need to do. 

      } else { 

       // permission denied, boo! Disable the 
       // functionality that depends on this permission. 
      } 
      return; 
     } 

     // other 'case' lines to check for other 
     // permissions this app might request 
    } 
} 

不幸的是,我没有客户端代码(如崩溃在谷歌控制台开发报告没有提及它)。在任何情况下,不应该React-Native检查是否为空的grantResults?这是一个错误?如果是的话,这怎么能被复制?我不认为有任何办法可以做到这一点,除非取消承诺,确保是否已启用权限(考虑反应原生权限API是不可能的)。

任何想法都非常受欢迎。先谢谢你。

+0

我遇到过类似的问题。加载我的应用程序的开发版本时请求权限。我认为它会在应用程序启动时将应用程序缩小,并导致崩溃。我不确定它是否仍然是生产中的问题。 – Culzean

回答

1

所以我终于找到了问题。无论何时出现权限请求对话框,如果用户最小化应用程序,然后通过从主菜单中单击应用程序的图标返回,则results为空,从而导致应用程序崩溃。

这似乎很安静一个简单的问题,我决定猴子补丁React-Native以防止不稳定的升级(现在我检查results数组是否为空,如果是,那么否认请求)。我仍然不知道这是一个常见问题还是来自我的应用程序。