2015-09-21 2 views
2

Я получаю аварии ниже в этой строке кода:Collections.sort вызывает java.lang.SecurityException: Требуется READ_PHONE_STATE

pkgMrg_global = getActivity().getPackageManager(); 
apps = pkgMrg_global.getInstalledApplications(0); 
//GETTING CRASH AT LINE BELOW 
Collections.sort(apps, 
         new ApplicationInfo.DisplayNameComparator(
           pkgMrg_global)); 

То, что я не понимаю, как Collections.sort ведет к этому Caused by: java.lang.SecurityException: Requires READ_PHONE_STATE: Neither user 10157 nor current process has android.permission.READ_PHONE_STATE?

StackTrace:

java.lang.RuntimeException: An error occured while executing doInBackground() 
at android.os.AsyncTask$3.done(AsyncTask.java:300) 
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355) 
at java.util.concurrent.FutureTask.setException(FutureTask.java:222) 
at java.util.concurrent.FutureTask.run(FutureTask.java:242) 
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
at java.lang.Thread.run(Thread.java:841) 

Caused by: java.lang.SecurityException: Requires READ_PHONE_STATE: Neither user 10157 nor current process has android.permission.READ_PHONE_STATE. 
at android.os.Parcel.readException(Parcel.java:1465) 
at android.os.Parcel.readException(Parcel.java:1419) 
at com.android.internal.telephony.IPhoneSubInfo$Stub$Proxy.getSubscriberId(IPhoneSubInfo.java:231) 
at android.telephony.TelephonyManager.getSubscriberId(TelephonyManager.java:1352) 
at android.app.ApplicationPackageManager.getSimOperatorNameForStk(ApplicationPackageManager.java:1548) 
at android.app.ApplicationPackageManager.getText(ApplicationPackageManager.java:1109) 
at android.content.pm.PackageItemInfo.loadLabel(PackageItemInfo.java:115) 
at android.app.ApplicationPackageManager.getApplicationLabel(ApplicationPackageManager.java:1186) 
at android.content.pm.ApplicationInfo$DisplayNameComparator.compare(ApplicationInfo.java:561) 
at android.content.pm.ApplicationInfo$DisplayNameComparator.compare(ApplicationInfo.java:554) 
at java.util.TimSort.binarySort(TimSort.java:261) 
at java.util.TimSort.sort(TimSort.java:204) 
at java.util.TimSort.sort(TimSort.java:169) 
at java.util.Arrays.sort(Arrays.java:2010) 
at java.util.Collections.sort(Collections.java:1883) 
at com.mavdev.focusoutfacebook.fragments.addablock.apps.Fragment_appsselect_addblock$loadAppsListfromSystem.doInBackground(Fragment_appsselect_addblock.java:1830) 
at com.mavdev.focusoutfacebook.fragments.addablock.apps.Fragment_appsselect_addblock$loadAppsListfromSystem.doInBackground(Fragment_appsselect_addblock.java:1802) 
at android.os.AsyncTask$2.call(AsyncTask.java:288) 
at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
... 4 more 
+0

добавить, что разрешение на ваш файл манифеста. – MetaSnarf

+0

причиной ошибки является либо '.getInstalledApplications (0);' или new 'ApplicationInfo.DisplayNameComparator (pkgMrg_global)' на ваш код – MetaSnarf

+0

Да, но я не понимаю, почему я должен это делать. Я не пользуюсь какой-либо функцией телефона (просто сортируя список приложений), поэтому не нужно это делать. Получил этот отчет с телефона пользователя, поэтому я не могу воспроизвести себя. – user1406716

ответ

0

добавить это разрешение вашего андроида манифеста

<uses-permission android:name="android.permission.READ_PHONE_STATE" />

2

Как в Google Docs here Примечание говорит Примечание: Если оба ваши minSdkVersion и targetSdkVersion значений установлены на 3 или ниже, система неявно предоставляет ваше приложение этому разрешению. Если вам не требуется это разрешение, убедитесь, что ваша целевая версияSdkVersion равна 4 или выше.

Степень защиты: опасный

если так вам нужно добавить разрешение

<uses-permission android:name="android.permission.READ_PHONE_STATE" />

Константа Значение: "android.permission.READ_PHONE_STATE"

Смежные вопросы