Android之网络连接判断

简介:

   Android进行网络联网的一些操作时,经常会对网络是否已经连接成功进行判断。我们通常会对wifi和移动网络进行判断,我们需要判断网络设备是否开启,是否连接成功,这里做个笔记哈。

 

 
  1. package com.example.util; 
  2.  
  3. import android.content.Context; 
  4. import android.net.ConnectivityManager; 
  5. import android.net.NetworkInfo; 
  6. import android.net.wifi.WifiManager; 
  7. import android.telephony.TelephonyManager; 
  8. import android.util.Log; 
  9.  
  10. /** 
  11.  *  
  12.  * @author XuZhiwei (xuzw13@gmail.com) 
  13.  * Weibo:http://weibo.com/xzw1989 
  14.  * Create at 2012-9-22 上午11:25:04 
  15.  */ 
  16. public class NetUtil {  
  17.      
  18.     /** 
  19.      * 判断Network是否开启(包括移动网络和wifi) 
  20.      *  
  21.      * @return 
  22.      */ 
  23.     public static boolean isNetworkEnabled(Context mContext) { 
  24.         return ( isNetEnabled(mContext)|| isWIFIEnabled(mContext)); 
  25.     } 
  26.      
  27.      
  28.     /** 
  29.      * 判断Network是否连接成功(包括移动网络和wifi) 
  30.      * @return 
  31.      */ 
  32.     public static boolean isNetworkConnected(Context mContext){ 
  33.         return (isWifiContected(mContext) || isNetContected(mContext)); 
  34.     } 
  35.  
  36.     /** 
  37.      * 判断移动网络是否开启 
  38.      *  
  39.      * @return 
  40.      */ 
  41.     public static boolean isNetEnabled(Context context) { 
  42.         boolean enable = false
  43.         TelephonyManager telephonyManager = (TelephonyManager) context 
  44.                 .getSystemService(Context.TELEPHONY_SERVICE); 
  45.         if (telephonyManager != null) { 
  46.             if (telephonyManager.getNetworkType() != TelephonyManager.NETWORK_TYPE_UNKNOWN) { 
  47.                 enable = true
  48.                 Log.i(Thread.currentThread().getName(), "isNetEnabled"); 
  49.             } 
  50.         } 
  51.  
  52.         return enable; 
  53.     } 
  54.  
  55.     /** 
  56.      * 判断wifi是否开启 
  57.      */ 
  58.     public static boolean isWIFIEnabled(Context context) { 
  59.         boolean enable = false
  60.         WifiManager wifiManager = (WifiManager) context 
  61.                 .getSystemService(Context.WIFI_SERVICE); 
  62.         if (wifiManager.isWifiEnabled()) { 
  63.             enable = true
  64.             Log.i(Thread.currentThread().getName(), "isWifiEnabled"); 
  65.         } 
  66.           
  67.         Log.i(Thread.currentThread().getName(), "isWifiDisabled"); 
  68.         return enable; 
  69.     } 
  70.     /** 
  71.      * 判断移动网络是否连接成功! 
  72.      * @param context 
  73.      * @return 
  74.      */ 
  75.     public static boolean isNetContected(Context context){ 
  76.         ConnectivityManager connectivityManager 
  77.              = (ConnectivityManager)context.getSystemService(Context.CONNECTIVITY_SERVICE); 
  78.          NetworkInfo mobileNetworkInfo = connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_MOBILE); 
  79.             if(mobileNetworkInfo.isConnected()) 
  80.             { 
  81.                  
  82.                 Log.i(Thread.currentThread().getName(), "isNetContected"); 
  83.                 return true ; 
  84.             } 
  85.             Log.i(Thread.currentThread().getName(), "isNetDisconnected"); 
  86.             return false ; 
  87.  
  88.     } 
  89.       
  90.     /** 
  91.      * 判断wifi是否连接成功 
  92.      * @param context 
  93.      * @return 
  94.      */ 
  95.     public static boolean isWifiContected(Context context){ 
  96.         ConnectivityManager connectivityManager 
  97.              = (ConnectivityManager)context.getSystemService(Context.CONNECTIVITY_SERVICE); 
  98.          NetworkInfo wifiNetworkInfo = connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI); 
  99.             if(wifiNetworkInfo.isConnected()) 
  100.             { 
  101.                  
  102.                 Log.i(Thread.currentThread().getName(), "isWifiContected"); 
  103.                 return true ; 
  104.             } 
  105.             Log.i(Thread.currentThread().getName(), "isWifiDisconnected"); 
  106.             return false ; 
  107.  
  108.     } 
  109.  

 

本文转自xuzw13 51CTO博客,原文链接:http://blog.51cto.com/xuzhiwei/1003059,如需转载请自行联系原作者

相关文章
|
2月前
|
Android开发
Android网络访问超时
Android网络访问超时
28 2
|
2月前
|
Java Linux API
统计android设备的网络数据使用量
统计android设备的网络数据使用量
52 0
|
28天前
|
缓存 网络协议 安全
Android网络面试题之Http基础和Http1.0的特点
**HTTP基础:GET和POST关键差异在于参数传递方式(GET在URL,POST在请求体),安全性(POST更安全),数据大小限制(POST无限制,GET有限制),速度(GET较快)及用途(GET用于获取,POST用于提交)。面试中常强调POST的安全性、数据量、数据类型支持及速度。HTTP 1.0引入了POST和HEAD方法,支持多种数据格式和缓存,但每个请求需新建TCP连接。**
28 5
|
26天前
|
安全 网络协议 算法
Android网络基础面试题之HTTPS的工作流程和原理
HTTPS简述 HTTPS基于TCP 443端口,通过CA证书确保服务器身份,使用DH算法协商对称密钥进行加密通信。流程包括TCP握手、证书验证(公钥解密,哈希对比)和数据加密传输(随机数加密,预主密钥,对称加密)。特点是安全但慢,易受特定攻击,且依赖可信的CA。每次请求可能复用Session ID以减少握手。
27 2
|
1月前
|
缓存 JSON 网络协议
Android面试题:App性能优化之电量优化和网络优化
这篇文章讨论了Android应用的电量和网络优化。电量优化涉及Doze和Standby模式,其中应用可能需要通过用户白名单或电池广播来适应限制。Battery Historian和Android Studio的Energy Profile是电量分析工具。建议减少不必要的操作,延迟非关键任务,合并网络请求。网络优化包括HTTPDNS减少DNS解析延迟,Keep-Alive复用连接,HTTP/2实现多路复用,以及使用protobuf和gzip压缩数据。其他策略如使用WebP图像格式,按网络质量提供不同分辨率的图片,以及启用HTTP缓存也是有效手段。
45 9
|
27天前
|
缓存 网络协议 Android开发
Android网络面试题之Http1.1和Http2.0
HTTP/1.1 引入持久连接和管道机制提升效率,支持分块传输编码和更多请求方式如PUT、PATCH。Host字段指定服务器域名,RANGE用于断点续传。HTTP/2变为二进制协议,实现多工处理,头信息压缩和服务器推送,减少延迟并优化资源加载。HTTP不断发展,从早期的简单传输到后来的高效交互。
26 0
Android网络面试题之Http1.1和Http2.0
|
1月前
|
JSON Java API
【Android】使用 Retrofit2 发送异步网络请求的简单案例
**摘要:** Retrofit是Android和Java的HTTP客户端库,简化了RESTful API交互。它通过Java接口定义HTTP请求,并提供注解管理参数、HTTP方法等。要使用Retrofit,首先在AndroidManifest.xml中添加`INTERNET`权限,然后在`build.gradle`中引入Retrofit和Gson依赖。创建服务器响应数据类和描述接口的接口,如`Result`和`Api`。通过Retrofit.Builder配置基础URL并构建实例,之后调用接口方法创建Call对象并发送异步请求。
59 1
|
1月前
|
缓存 网络协议 Java
Android面试题之Java网络通信基础知识
Socket是应用与TCP/IP通信的接口,封装了底层细节。网络通信涉及连接、读写数据。BIO是同步阻塞,NIO支持多路复用(如Selector),AIO在某些平台提供异步非阻塞服务。BIO示例中,服务端用固定线程池处理客户端请求,客户端发起连接并读写数据。NIO的关键是Selector监控多个通道的事件,减少线程消耗。书中推荐《Java网络编程》和《UNIX网络编程》。关注公众号AntDream了解更多。
26 2
|
1月前
|
XML JSON Java
Android面试题 之 网络通信基础面试题
序列化对比:Serializable码流大、性能低;XML人机可读但复杂;JSON轻量、兼容性好但空间消耗大;ProtoBuff高效紧凑。支持大量长连接涉及系统限制调整、缓冲区优化。select/poll/epoll是IO多路复用,epoll在高连接数下性能更优且支持边缘触发。水平触发持续通知数据,边缘触发仅通知新数据。直接内存减少一次拷贝,零拷贝技术如sendfile和MMAP提升效率。关注公众号"AntDream"了解更多技术细节。
20 1
|
1月前
|
安全 Android开发 数据安全/隐私保护
同样的 APP 为何在 Android 8 以后网络感觉变卡?
【6月更文挑战第8天】Android 8 及以后系统中,APP 网络感觉变卡源于更严格的安全机制和后台限制,系统对网络优化的侧重改变,以及APP自身兼容性问题。开发者需优化APP,适应新系统,用户可更新APP或检查权限设置。通过共同努力,有望改善网络卡顿现象,提升用户体验。