没有详细信息的 java.lang.SecurityException
Posted
技术标签:
【中文标题】没有详细信息的 java.lang.SecurityException【英文标题】:java.lang.SecurityException with No Details 【发布时间】:2018-05-30 14:34:10 【问题描述】:我四处寻找这个问题,但找不到我的案例的解决方案。我刚刚更新了我的应用程序以针对 android API 25。因此我必须更新权限处理。我的应用需要以下权限:
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.READ_PROFILE" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.INTERNET" />
我添加了所有代码来检查/请求权限,并在两部不同的手机上进行了测试。然而,一些用户遇到了这个崩溃:
java.lang.RuntimeException:
at android.os.AsyncTask$3.done (AsyncTask.java:318)
at java.util.concurrent.FutureTask.finishCompletion (FutureTask.java:354)
at java.util.concurrent.FutureTask.setException (FutureTask.java:223)
at java.util.concurrent.FutureTask.run (FutureTask.java:242)
at java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run (ThreadPoolExecutor.java:607)
at java.lang.Thread.run (Thread.java:762)
Caused by: java.lang.SecurityException:
at android.os.Parcel.readException (Parcel.java:1693)
at android.os.Parcel.readException (Parcel.java:1646)
at android.app.ActivityManagerProxy.getContentProvider (ActivityManagerNative.java:4912)
at android.app.ActivityThread.acquireProvider (ActivityThread.java:6043)
at android.app.ContextImpl$ApplicationContentResolver.acquireUnstableProvider (ContextImpl.java:2474)
at android.content.ContentResolver.acquireUnstableProvider (ContentResolver.java:1521)
at android.content.ContentResolver.query (ContentResolver.java:520)
at android.content.CursorLoader.loadInBackground (CursorLoader.java:64)
at android.content.CursorLoader.loadInBackground (CursorLoader.java:56)
at android.content.AsyncTaskLoader.onLoadInBackground (AsyncTaskLoader.java:312)
at android.content.AsyncTaskLoader$LoadTask.doInBackground (AsyncTaskLoader.java:69)
at android.content.AsyncTaskLoader$LoadTask.doInBackground (AsyncTaskLoader.java:66)
at android.os.AsyncTask$2.call (AsyncTask.java:304)
at java.util.concurrent.FutureTask.run (FutureTask.java:237)
如您所见,我收到了一个没有详细信息的安全异常。堆栈跟踪还显示它根本不是源自我的代码。
谁能告诉我如何解决这个问题?我读错了堆栈跟踪吗?
编辑:问题必须源于尝试从联系人建立用户电子邮件列表。代码如下:
@Override
public Loader<Cursor> onCreateLoader(int i, Bundle bundle)
return new CursorLoader(this,
// Retrieve data rows for the device user's 'profile' contact.
Uri.withAppendedPath(ContactsContract.Profile.CONTENT_URI,
ContactsContract.Contacts.Data.CONTENT_DIRECTORY), ProfileQuery.PROJECTION,
// Select only email addresses.
ContactsContract.Contacts.Data.MIMETYPE +
" = ?", new String[]ContactsContract.CommonDataKinds.Email
.CONTENT_ITEM_TYPE,
// Show primary email addresses first. Note that there won't be
// a primary email address if the user hasn't specified one.
ContactsContract.Contacts.Data.IS_PRIMARY + " DESC");
@Override
public void onLoadFinished(Loader<Cursor> cursorLoader, Cursor cursor)
List<String> emails = new ArrayList<>();
cursor.moveToFirst();
while (!cursor.isAfterLast())
emails.add(cursor.getString(ProfileQuery.ADDRESS));
cursor.moveToNext();
addEmailsToAutoComplete(emails);
【问题讨论】:
向问题添加更多细节,堆栈跟踪似乎不完整 你在你的应用中使用CursorLoader
吗?
我的代码使用CursorLoader
填充来自联系人的用户电子邮件。
这是来自 Google Play 控制台的整个堆栈跟踪。调试我有的两部安卓手机时无法重现。
【参考方案1】:
我发现发生了什么。在我的代码中有一个更晦涩的地方调用这个:
getLoaderManager().initLoader(0, null, this);
解决方案是在获取用户联系数据之前进行正常的权限检查。
事实证明,Google Play 控制台不会在其堆栈跟踪中显示安全异常详细信息。只能在调试模式下看到实际需要的权限。
【讨论】:
“进行正常的权限检查”是什么意思。你有代码示例吗?以上是关于没有详细信息的 java.lang.SecurityException的主要内容,如果未能解决你的问题,请参考以下文章