广播注册:
1. IntentFilter filter = new IntentFilter();
2. filter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
3. filter.addAction("android.net.wifi.WIFI_STATE_CHANGED");
4. filter.addAction("android.net.wifi.STATE_CHANGE");
5. registerReceiver(mNetworkChangeListener,filter);
广播接收者的具体代码如下,主要是几个广播的几个intent.getAction()的含义,需要多注意。
- 监听网络的改变状态,只有在用户操作网络连接开关(wifi,mobile)的时候接受广播,
然后对相应的界面进行相应的操作,并将 状态 保存在我们的APP里面
public class NetworkConnectChangedReceiver extends BroadcastReceiver { private static final String TAG = "xujun"; public static final String TAG1 = "xxx"; @Override public void onReceive(Context context, Intent intent) { // 这个监听wifi的打开与关闭,与wifi的连接无关 if (WifiManager.WIFI_STATE_CHANGED_ACTION.equals(intent.getAction())) { int wifiState = intent.getIntExtra(WifiManager.EXTRA_WIFI_STATE, 0); Log.e(TAG1, "wifiState" + wifiState); switch (wifiState) { case WifiManager.WIFI_STATE_DISABLED: APP.getInstance().setEnablaWifi(false); break; case WifiManager.WIFI_STATE_DISABLING: break; case WifiManager.WIFI_STATE_ENABLING: break; case WifiManager.WIFI_STATE_ENABLED: APP.getInstance().setEnablaWifi(true); break; case WifiManager.WIFI_STATE_UNKNOWN: break; default: break; } } // 这个监听wifi的连接状态即是否连上了一个有效无线路由,当上边广播的状态是WifiManager // .WIFI_STATE_DISABLING,和WIFI_STATE_DISABLED的时候,根本不会接到这个广播。 // 在上边广播接到广播是WifiManager.WIFI_STATE_ENABLED状态的同时也会接到这个广播, // 当然刚打开wifi肯定还没有连接到有效的无线 if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(intent.getAction())) { Parcelable parcelableExtra = intent .getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO); if (null != parcelableExtra) { NetworkInfo networkInfo = (NetworkInfo) parcelableExtra; State state = networkInfo.getState(); boolean isConnected = state == State.CONNECTED;// 当然,这边可以更精确的确定状态 Log.e(TAG1, "isConnected" + isConnected); if (isConnected) { APP.getInstance().setWifi(true); } else { APP.getInstance().setWifi(false); } } } // 这个监听网络连接的设置,包括wifi和移动数据的打开和关闭。. // 最好用的还是这个监听。wifi如果打开,关闭,以及连接上可用的连接都会接到监听。见log // 这个广播的最大弊端是比上边两个广播的反应要慢,如果只是要监听wifi,我觉得还是用上边两个配合比较合适 if (ConnectivityManager.CONNECTIVITY_ACTION.equals(intent.getAction())) { ConnectivityManager manager = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); Log.i(TAG1, "CONNECTIVITY_ACTION"); NetworkInfo activeNetwork = manager.getActiveNetworkInfo(); if (activeNetwork != null) { // connected to the internet if (activeNetwork.isConnected()) { if (activeNetwork.getType() == ConnectivityManager.TYPE_WIFI) { // connected to wifi APP.getInstance().setWifi(true); Log.e(TAG, "当前WiFi连接可用 "); } else if (activeNetwork.getType() == ConnectivityManager.TYPE_MOBILE) { // connected to the mobile provider's data plan APP.getInstance().setMobile(true); Log.e(TAG, "当前移动网络连接可用 "); } } else { Log.e(TAG, "当前没有网络连接,请确保你已经打开网络 "); } Log.e(TAG1, "info.getTypeName()" + activeNetwork.getTypeName()); Log.e(TAG1, "getSubtypeName()" + activeNetwork.getSubtypeName()); Log.e(TAG1, "getState()" + activeNetwork.getState()); Log.e(TAG1, "getDetailedState()" + activeNetwork.getDetailedState().name()); Log.e(TAG1, "getDetailedState()" + activeNetwork.getExtraInfo()); Log.e(TAG1, "getType()" + activeNetwork.getType()); } else { // not connected to the internet Log.e(TAG, "当前没有网络连接,请确保你已经打开网络 "); APP.getInstance().setWifi(false); APP.getInstance().setMobile(false); APP.getInstance().setConnected(false); } } } }
从上面的代码中,我们可以知道我们将我们当前的网络状态保存在我们的 APP 里面,这样当网络状态变化的时候会自动去改变 APP 里面相应的状态量,我们进行网络处理的 时候只需要去获取 APP里面的状态量,便可以判断出是属于哪一种网络错误,是不是很方便呢。
至于广播的Action主要有三种类型:
WifiManager.WIFI_STATE_CHANGED_ACTION
这个监听wifi的打开与关闭,与wifi的连接无关
WifiManager.NETWORK_STATE_CHANGED_ACTION
这个监听wifi的连接状态即是否连上了一个有效无线路由,当上边广播的状态是WifiManager.WIFI_STATE_DISABLING,和WIFI_STATE_DISABLED的时候,根本不会接到这个广播。
在上边广播接到广播是WifiManager.WIFI_STATE_ENABLED状态的同时也会接到这个广播,当然刚打开wifi肯定还没有连接到有效的无线
ConnectivityManager.CONNECTIVITY_ACTION
这个监听网络连接的设置,包括wifi和移动数据的打开和关闭。.
最好用的还是这个监听。wifi如果打开,关闭,以及连接上可用的连接都会接到监听。这个广播的最大弊端是比上边两个广播的反应要慢,如果只是要监听wifi,我觉得还是用上边两个配合比较合适。
有问题和想法,欢迎私信或者评论留言,一起学习,一起进步!
参考资料:https://blog.csdn.net/gdutxiaoxu/article/details/53008266