无法从NetWorkInfo Android获取状态

时间:2015-02-08 13:04:51

标签: java android state telephonymanager android-broadcastreceiver

正如标题所说,我无法从NetWorkInfo Class获得Broadcastreceiver中的State。

它返回日志输出中的一些错误,如下所示。

我需要你的帮助。

这是日志输出和Broacastreceiver类,我还注意到我已经添加了所有权限(Access Network State et Internet)和广播意图action android:name="android.net.conn.CONNECTIVITY_CHANGE

所以我敢说manifest.xml文件中没有问题。

ConnectivityManager cm =
            (ConnectivityManager)context.getSystemService(Context.CONNECTIVITY_SERVICE);

    NetworkInfo activeNetwork = cm.getActiveNetworkInfo();

    State state = activeNetwork.getState();

  switch (state) {

  case CONNECTING:
      Toast.makeText(context, "connecting", Toast.LENGTH_SHORT).show();
  break;

并且日志输出为:

java.lang.RuntimeException: Unable to start receiver com.example.test.ConnectivityChangeReceiver: java.lang.NullPointerException
E/AndroidRuntime( 9873):    at android.app.ActivityThread.handleReceiver(ActivityThread.java:2668)
E/AndroidRuntime( 9873):    at android.app.ActivityThread.access$1800(ActivityThread.java:172)
E/AndroidRuntime( 9873):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1384)
E/AndroidRuntime( 9873):    at android.os.Handler.dispatchMessage(Handler.java:102)
E/AndroidRuntime( 9873):    at android.os.Looper.loop(Looper.java:146)
E/AndroidRuntime( 9873):    at android.app.ActivityThread.main(ActivityThread.java:5653)
E/AndroidRuntime( 9873):    at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 9873):    at java.lang.reflect.Method.invoke(Method.java:515)
E/AndroidRuntime( 9873):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
E/AndroidRuntime( 9873):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
E/AndroidRuntime( 9873):    at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime( 9873): Caused by: java.lang.NullPointerException
E/AndroidRuntime( 9873):    at com.example.test.ConnectivityChangeReceiver.onReceive(ConnectivityChangeReceiver.java:27)
E/AndroidRuntime( 9873):    at android.app.ActivityThread.handleReceiver(ActivityThread.java:2653)

2 个答案:

答案 0 :(得分:1)

您正在此行activeNetwork.getState()上获取NPE,因为activeNetworknull当没有默认网络时,这可能会返回null。

在测试此应用时,请确保有Active Network。在这种情况下,activeNetwork.getState()应为非空。

如果您的目标是测试Wi-Fi和移动设备的网络连接,那么您可以尝试使用以下代码:

ConnectivityManager cm =
                (ConnectivityManager)context.getSystemService(Context.CONNECTIVITY_SERVICE);

        NetworkInfo networkInfo = cm.getNetworkInfo(ConnectivityManager.TYPE_WIFI); 
        boolean isWifiConn = networkInfo.isConnected();
        networkInfo = cm.getNetworkInfo(ConnectivityManager.TYPE_MOBILE);
        boolean isMobileConn = networkInfo.isConnected();


        Log.d("ConnectivityChangeReceiver", "Wifi connected: " + isWifiConn);
        Log.d("ConnectivityChangeReceiver", "Mobile connected: " + isMobileConn);

此代码确定这些网络接口是否可用(即,是否可以进行网络连接)和/或已连接(即,是否存在网络连接以及是否可以建立套接字并传递数据。

此外,您不应该根据网络是否“可用”做出决定。在执行网络操作之前​​,您应该始终检查isConnected(),因为isConnected()处理诸如片状移动网络,飞行模式和受限制的背景数据之类的情况。

public boolean isOnline() {
    ConnectivityManager connMgr = (ConnectivityManager) 
            getSystemService(Context.CONNECTIVITY_SERVICE);
    NetworkInfo networkInfo = connMgr.getActiveNetworkInfo();
    return (networkInfo != null && networkInfo.isConnected());
} 

答案 1 :(得分:0)

我相信您在清单中缺少以下权限。

[root@xg bin]# curl http://localhost:9200/_cat/indices?pretty
green  open graylog2_0    4 0  0 0    576b    576b 
yellow open xg-2015.12.12 5 1 56 0 335.4kb 335.4kb 
[root@xg bin]#