Почему приложение запускается при запуске только на API 26 - PullRequest
0 голосов
/ 18 сентября 2018

У меня есть приложение, работающее на каждом API полностью, но в Android 8 API 26 оно падает, и я не знаю, почему это произошло.

Приложение использует смс отправку и получение разрешений, и я помещаю все requestPermissions в активность и манифесты.Целевой SDK находится на 26

Вот логкат ошибки андроид-студии при сбое приложения:

hapital.com.BitCar E/AndroidRuntime: FATAL EXCEPTION: main Process: hapital.com.BitCar, PID: 25271
java.lang.RuntimeException: Unable to start activity ComponentInfo{hapital.com.BitCar/hapital.com.BitCar.MainActivity}: java.lang.IllegalArgumentException: Invalid destinationAddress
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2817)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892)
    at android.app.ActivityThread.-wrap11(Unknown Source:0)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593)
    at android.os.Handler.dispatchMessage(Handler.java:105)
    at android.os.Looper.loop(Looper.java:164)
    at android.app.ActivityThread.main(ActivityThread.java:6541)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
 Caused by: java.lang.IllegalArgumentException: Invalid destinationAddress
    at android.telephony.SmsManager.sendTextMessageInternal(SmsManager.java:320)
    at android.telephony.SmsManager.sendTextMessage(SmsManager.java:312)
    at hapital.com.BitCar.MainActivity.onCreate(MainActivity.java:194)
    at android.app.Activity.performCreate(Activity.java:6975)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1213)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2770)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892) 
    at android.app.ActivityThread.-wrap11(Unknown Source:0) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593) 
    at android.os.Handler.dispatchMessage(Handler.java:105) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6541) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 

Неверный адрес назначенияАдрес ??что это значит ??

Например, у него есть ошибка на SmsManager.java, когда он открывается, как и на картинке ниже, есть ошибка в библиотеках импорта введите описание изображения здесь

Может ли кто-нибудь помочь, что мне делать?

Ответы [ 2 ]

0 голосов
/ 17 ноября 2018

наконец-то я обнаружил проблему

проблема была в макете активности, который я использовал NavigationView, как belo:

<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="230dp"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main2"
app:menu="@menu/activity_main2_drawer" />

и в API 26 и выше не поддерживается

0 голосов
/ 18 сентября 2018

Согласно исходному коду SmsManager, это исключение выдается, когда вы вызываете sendTextMessage с параметром адреса назначения, равным null или пустым String.

Если ваш кодотправьте SMS (согласно вашему комментарию) так:

 SharedPreferences panelnumber = getSharedPreferences("Prefs", MODE_PRIVATE);
 String string_from_sp = panelnumber.getString("myStringName", ""); 
 SmsManager smsManager = SmsManager.getDefault();
 smsManager.sendTextMessage(string_from_sp.toString(), null,
                            smsBody.toString(), null, null);

, тогда из этого следует, что string_from_sp является null или пустым String.

.при инициализации этой переменной либо:

  • поле "mystringName", полученное из предпочтений, пусто, либо
  • у вас неверное имя поля предпочтения, и вы получаете значение по умолчанию, котороевы указали пустое значение String.

Недостаточно информации, чтобы объяснить, почему это происходит только с API 26 ... если это то, что вы говорите.

...