Android wifi状态三种广播

public class NetworkConnectChangedReceiver extends BroadcastReceiver{
	@Override
	public void onReceive(Context context, Intent intent) {
	if (WifiManager.WIFI_STATE_CHANGED_ACTION.equals(intent.getAction())) {//这个监听wifi的打开与关闭,与wifi的连接无关
            int wifiState = intent.getIntExtra(WifiManager.EXTRA_WIFI_STATE, 0); 
            LogTag.showTAG_e("WIFI状态", "wifiState"+wifiState);
            switch (wifiState) { 
            case WifiManager.WIFI_STATE_DISABLED: 
                break; 
            case WifiManager.WIFI_STATE_DISABLING: 
                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;//当然,这边可以更精确的确定状态
                LogTag.showTAG_e(this.getClass().getSimpleName(), "isConnected"+isConnected);
                if(isConnected){
                }else{
                	
                }
            }  
        }
	//这个监听网络连接的设置,包括wifi和移动数据的打开和关闭。. 
        //最好用的还是这个监听。wifi如果打开,关闭,以及连接上可用的连接都会接到监听。见log
        // 这个广播的最大弊端是比上边两个广播的反应要慢,如果只是要监听wifi,我觉得还是用上边两个配合比较合适
	if(ConnectivityManager.CONNECTIVITY_ACTION.equals(intent.getAction())){
		NetworkInfo info = intent.getParcelableExtra(ConnectivityManager.EXTRA_NETWORK_INFO);
		if (info != null) {
			LogTag.showTAG_e("CONNECTIVITY_ACTION", "info.getTypeName()"+info.getTypeName());
			LogTag.showTAG_e("CONNECTIVITY_ACTION", "getSubtypeName()"+info.getSubtypeName());
			LogTag.showTAG_e("CONNECTIVITY_ACTION", "getState()"+info.getState());
			LogTag.showTAG_e("CONNECTIVITY_ACTION",
                                "getDetailedState()"+info.getDetailedState().name());
			LogTag.showTAG_e("CONNECTIVITY_ACTION", "getDetailedState()"+info.getExtraInfo());
			LogTag.showTAG_e("CONNECTIVITY_ACTION", "getType()"+info.getType());
		} 
	}

/**
08-29 19:51:30.366: E/CONNECTIVITY_ACTION(16920): ========info.getTypeName()WIFI=============
08-29 19:51:30.366: E/CONNECTIVITY_ACTION(16920): ========getSubtypeName()=============
08-29 19:51:30.366: E/CONNECTIVITY_ACTION(16920): ========getState()DISCONNECTED=============
08-29 19:51:30.366: E/CONNECTIVITY_ACTION(16920): ========getDetailedState()DISCONNECTED=============
08-29 19:51:30.366: E/CONNECTIVITY_ACTION(16920): ========getDetailedState()null=============
08-29 19:51:30.366: E/CONNECTIVITY_ACTION(16920): ========getType()1=============
---------------
08-29 19:52:35.757: E/CONNECTIVITY_ACTION(16920): ========info.getTypeName()mobile=============
08-29 19:52:35.757: E/CONNECTIVITY_ACTION(16920): ========getSubtypeName()HSPA=============
08-29 19:52:35.757: E/CONNECTIVITY_ACTION(16920): ========getState()CONNECTED=============
08-29 19:52:35.757: E/CONNECTIVITY_ACTION(16920): ========getDetailedState()CONNECTED=============
08-29 19:52:35.757: E/CONNECTIVITY_ACTION(16920): ========getDetailedState()3gnet=============
08-29 19:52:35.757: E/CONNECTIVITY_ACTION(16920): ========getType()0=============
		 */
	}


}


最终监听wifi提示的代码

	if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(intent.getAction())) {// 这个监听wifi的连接状态
            Parcelable parcelableExtra = intent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO);  
            if (null != parcelableExtra) {  
                NetworkInfo networkInfo = (NetworkInfo) parcelableExtra;  
                State state = networkInfo.getState();
                if(state==State.CONNECTED){
                	showWifiCconnected(context);
                }
                /**else if(state==State.DISCONNECTED){
                	showWifiDisconnected(context);
                }*///昨天写的这个方法,在坐地铁的时候发现,如果地铁上有无效的wifi站点,手机会自动连接,但是连接失败后还是会接到广播,所以不能用了
            }  
        }
	if(ConnectivityManager.CONNECTIVITY_ACTION.equals(intent.getAction())){//这个监听网络连接的设置,包括wifi和移动数据 的打开和关闭
	NetworkInfo info = intent.getParcelableExtra(ConnectivityManager.EXTRA_NETWORK_INFO);
	if (info != null) {
		if(NetworkInfo.State.CONNECTED==info.getState()){
			Intent pushIntent = new Intent();
			pushIntent.setClass(context, NotificationService.class);
		}else if(info.getType()==1){
	         	if(NetworkInfo.State.DISCONNECTING==info.getState())
		         	showWifiDisconnected(context);
			}
		} 
	}
        }


打开和关闭2g/3g网络,以及wifi收到的日志信息

2g打开情况,关闭wifi
07-10 20:30:57.764: I/System.out(24781): NetworkInfo: type: WIFI[], state: DISCONNECTED/DISCONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: false
07-10 20:31:00.460: I/System.out(24781): NetworkInfo: type: mobile[HSPA], state: CONNECTED/CONNECTED, reason: apnSwitched, extra: 3gnet, roaming: false, failover: false, isAvailable: true

wifi关闭情况,关闭2g
07-10 20:31:11.366: I/System.out(24781): NetworkInfo: type: mobile[HSPA], state: DISCONNECTED/DISCONNECTED, reason: dataDisabled, extra: 3gnet, roaming: false, failover: false, isAvailable: true

wifi关闭情况,打开2g
07-10 20:33:10.913: I/System.out(24781): NetworkInfo: type: mobile[HSPA], state: CONNECTED/CONNECTED, reason: apnSwitched, extra: 3gnet, roaming: false, failover: false, isAvailable: true

 

2G打开情况,打开wifi
07-10 20:33:43.764: I/System.out(24781): NetworkInfo: type: WIFI[], state: CONNECTED/CONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: true

07-10 20:33:44.272: I/System.out(24781): NetworkInfo: type: mobile[HSPA], state: DISCONNECTED/DISCONNECTED, reason: dataDisabled, extra: 3gnet, roaming: false, failover: false, isAvailable: true

07-10 20:33:44.569: I/System.out(24781): NetworkInfo: type: WIFI[], state: CONNECTED/CONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: true

wifi 打开情况,关闭2g


2g关闭情况,关闭wifi
07-10 20:36:00.702: I/System.out(24781): NetworkInfo: type: WIFI[], state: DISCONNECTED/DISCONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: false

2G关闭情况,打开wifi
07-10 20:38:31.632: I/System.out(25310): NetworkInfo: type: WIFI[], state: CONNECTED/CONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: true   info.getType 1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值