背景:不停弹出的Toast
我们在某个页面的onResume中进行了权限的判断和申请,在权限拒绝的回调onRequestPermissionsResult中添加了一个Toast提示权限获取失败。结果发现权限被拒绝并且“拒绝后不再提示”,Toast不停弹出。同时页面的点击事件失效。
定位过程
log显示页面的onPause/onResume和onRequestPermissionsResult不停回调。排查onResume代码发现了权限判断和申请代码。注释后解决Toast不停弹出和点击事件失效问题(onPause状态无法交互)。
根本原因(转自下面相关链接)
进入页面时会弹出一个权限申请弹框,如果点击允许一切正常,如果点击拒绝,会重新弹出权限申请对话框,一直拒绝的话会一直弹出。如果点击拒绝并且不再提醒,不会继续弹框,但是页面返回按钮不响应,观察日志发现onResume中请求权限的代码循环执行。
看下Activity的requestPermissions方法
public final void requestPermissions(@NonNull String[] permissions, int requestCode) {
if (requestCode < 0) {
throw new IllegalArgumentException("requestCode should be >= 0");
}
if (mHasCurrentPermissionsRequest) {
Log.w(TAG, "Can request only one set of permissions at a time");
onRequestPermissionsResult(requestCode, new String[0], new int[0]);
return;
}
Intent intent = getPackageManager().buildRequestPermissionsIntent(permissions);
startActivityForResult(REQUEST_PERMISSIONS_WHO_PREFIX, intent, requestCode, null);
mHasCurrentPermissionsRequest = true;
}
Activity里面请求权限的时候会启动一个权限的Activity,请求权限结束后会先回调onRequestPermissionsResult,然后执行onResume,所以如果点拒绝且不再提示的话会循环执行请求权限的代码。
后续优化
在onResume中仅做权限判断,不做权限申请,权限申请交给button或者dialog点击事件去做。
相关链接
《不要在onResume中申请权限》
|