【问题标题】:Creating a NotificationChannel throws an IllegalArgumentException创建 NotificationChannel 会引发 IllegalArgumentException
【发布时间】:2018-03-02 16:07:37
【问题描述】:

该应用适用于以前版本的 Android,但不适用于 Oreo。这是WebViewNotifications。我一直在研究这个错误,没有发现类似的东西。

堆栈跟踪:

E/AndroidRuntime: FATAL EXCEPTION: main
Process: net.oneteamit.tk, PID: 3171
java.lang.RuntimeException: Unable to start activity ComponentInfo{net.oneteamit.tk/net.oneteamit.tk.MainActivity}:
    java.lang.IllegalArgumentException
    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
    at android.os.Parcel.readException(Parcel.java:1946)
    at android.os.Parcel.readException(Parcel.java:1888)
    at android.app.INotificationManager$Stub$Proxy.createNotificationChannels(INotificationManager.java:1418)
    at android.app.NotificationManager.createNotificationChannels(NotificationManager.java:446)
    at android.app.NotificationManager.createNotificationChannel(NotificationManager.java:434)
    at net.oneteamit.tk.MainActivity.onCreate(MainActivity.java:47)
    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) 

MainActivity:

public class MainActivity extends AppCompatActivity {

    private WebView mWebView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mWebView = (WebView) findViewById(R.id.activity_main_webview);
        WebSettings webSettings = mWebView.getSettings();
        webSettings.setJavaScriptEnabled(true);
        mWebView.loadUrl("My test URL");
        mWebView.setWebViewClient(new WebViewClient());
        mWebView.getSettings().setAppCacheEnabled(false);
        mWebView.clearCache(true);

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            // Create channel to show notifications.
            String channelId  = getString(R.string.default_notification_channel_id);
            String channelName = getString(R.string.default_notification_channel_name);

            NotificationManager notificationManager =
                getSystemService(NotificationManager.class);

            notificationManager.createNotificationChannel(
                new NotificationChannel(channelId,
                                        channelName,
                                        NotificationManager.IMPORTANCE_LOW));
        }

        mWebView.getSettings().setUseWideViewPort(true);
        mWebView.getSettings().setLoadWithOverviewMode(true);
        mWebView.setInitialScale(1);
        mWebView.getSettings().setBuiltInZoomControls(true);
    }
}

【问题讨论】:

  • 注释掉对notificationManager.createNotificationChannel(...);的调用以查看异常是否仍然发生。检查default_notification_channel_iddefault_notification_channel_name 的值不为空或为空。
  • 这成功了!我刚刚注释掉了我对 notificationManager.createNotificationChannel(...) 的 2 行,它起作用了。
  • 您必须进行试验才能了解创建频道失败的原因。可能您的频道 ID 或频道名称无效。

标签: android android-notifications illegalargumentexception


【解决方案1】:

当频道名称无效时会发生此异常。我能够通过使用空通道名称运行来重现堆栈跟踪:

<string name="default_notification_channel_name"></string>

检查您为default_notification_channel_name 定义的值并将其更改为有效值。

【讨论】:

    【解决方案2】:

    &lt;string name="app_name"&gt;&lt;/string&gt; 是这个错误的原因。空字符串会导致 FATAL EXCEPTION。

    【讨论】:

      【解决方案3】:

      AppCompactActivity 向后兼容但不向前兼容,您正在使用的组件是否不受 Android 8.0 支持,或者 Android Studio 或 IDE 是否与 Oreo 是最新的。

      【讨论】:

      • 不确定,我正在研究,但到目前为止通知部分应该可以工作。
      • 我有另一个应用程序,它只是一个 webview,适用于 jellybean 和 Oreo,我没有更改这个,但我当前的应用程序是一个副本,其中包含 firebase 通知。
      猜你喜欢
      • 2022-01-09
      • 1970-01-01
      • 2010-11-14
      • 1970-01-01
      • 2015-02-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-02-09
      相关资源
      最近更新 更多