平時我們在請求錯誤的情況下,通常會進行處理一下,一般來說,主要分為兩方面的錯誤
專注于為中小企業(yè)提供網(wǎng)站設計制作、做網(wǎng)站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)涇縣免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了成百上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
今天這篇博客主要闡述以下問題
實現(xiàn)思路
在網(wǎng)絡錯誤的情況下獲取網(wǎng)絡狀態(tài)進行判斷,這種方法是可行的,但你想過了沒有,如果每次都要進行這樣的判斷,豈不是代碼量很多?有人會說,那把代碼封裝到一個類不就好了嗎?這樣確實能減少代碼量,但是每次都要主動去獲取,這樣是不是挺麻煩的。實際上,google 早就幫我們封裝好了,在網(wǎng)絡狀態(tài)變化的情況下會發(fā)出廣播,我們只需要監(jiān)聽廣播就好了 。
使用靜態(tài)廣播還是動態(tài)注冊廣播的方式好呢?
如果你不太清楚的話,我只能說即 基礎不扎實。我們的應用之所以要監(jiān)聽網(wǎng)絡狀態(tài)的 變化,主要是為了在錯誤的情況下方便進行處理,退出我們當前的應用之后當然不需要監(jiān)聽了,所以選擇動態(tài)注冊廣播。
共同點:都需要在AndroidMainest清單文件里面注冊
通過廣播監(jiān)聽網(wǎng)絡狀態(tài)的兩種方法
靜態(tài)注冊
動態(tài)注冊
第一步:在AndroidMainest文件里面注冊
第二步:調(diào)用 Context registerReceiver(Receiver,IntentFilter) 進行注冊
IntentFilter filter = new IntentFilter(); filter.addAction("android.net.conn.CONNECTIVITY_CHANGE"); filter.addAction("android.net.wifi.WIFI_STATE_CHANGED"); filter.addAction("android.net.wifi.STATE_CHANGE"); registerReceiver(mNetworkChangeListener,filter);
我們自定義的NetworkChangeListener廣播
/** * 網(wǎng)絡改變監(jiān)控廣播 ** 監(jiān)聽網(wǎng)絡的改變狀態(tài),只有在用戶操作網(wǎng)絡連接開關(guān)(wifi,mobile)的時候接受廣播, * 然后對相應的界面進行相應的操作,并將 狀態(tài) 保存在我們的APP里面 *
*
* Created by xujun */ 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) { // 這個監(jiān)聽wifi的打開與關(guān)閉,與wifi的連接無關(guān) 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; } } // 這個監(jiān)聽wifi的連接狀態(tài)即是否連上了一個有效無線路由,當上邊廣播的狀態(tài)是WifiManager // .WIFI_STATE_DISABLING,和WIFI_STATE_DISABLED的時候,根本不會接到這個廣播。 // 在上邊廣播接到廣播是WifiManager.WIFI_STATE_ENABLED狀態(tài)的同時也會接到這個廣播, // 當然剛打開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;// 當然,這邊可以更精確的確定狀態(tài) Log.e(TAG1, "isConnected" + isConnected); if (isConnected) { APP.getInstance().setWifi(true); } else { APP.getInstance().setWifi(false); } } } // 這個監(jiān)聽網(wǎng)絡連接的設置,包括wifi和移動數(shù)據(jù)的打開和關(guān)閉。. // 最好用的還是這個監(jiān)聽。wifi如果打開,關(guān)閉,以及連接上可用的連接都會接到監(jiān)聽。見log // 這個廣播的最大弊端是比上邊兩個廣播的反應要慢,如果只是要監(jiān)聽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, "當前移動網(wǎng)絡連接可用 "); } } else { Log.e(TAG, "當前沒有網(wǎng)絡連接,請確保你已經(jīng)打開網(wǎng)絡 "); } 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, "當前沒有網(wǎng)絡連接,請確保你已經(jīng)打開網(wǎng)絡 "); APP.getInstance().setWifi(false); APP.getInstance().setMobile(false); APP.getInstance().setConnected(false); } } } }
最后,別忘記添加一下權(quán)限
思路解析
從上面的代碼中,我們可以知道我們將我們當前的網(wǎng)絡狀態(tài)保存在我們的 APP 里面,這樣當網(wǎng)絡狀態(tài)變化的時候會自動去改變 APP 里面相應的狀態(tài)量,我們進行網(wǎng)絡處理的 時候只需要去獲取 APP里面的狀態(tài)量,便可以判斷出是屬于哪一種網(wǎng)絡錯誤,是不是很方便呢。
至于廣播的Action主要有三種類型:
WifiManager.WIFI_STATE_CHANGED_ACTION
這個監(jiān)聽wifi的打開與關(guān)閉,與wifi的連接無關(guān)
WifiManager.NETWORK_STATE_CHANGED_ACTION:
這個監(jiān)聽wifi的連接狀態(tài)即是否連上了一個有效無線路由,當上邊廣播的狀態(tài)是WifiManager.WIFI_STATE_DISABLING,和WIFI_STATE_DISABLED的時候,根本不會接到這個廣播。
在上邊廣播接到廣播是WifiManager.WIFI_STATE_ENABLED狀態(tài)的同時也會接到這個廣播,當然剛打開wifi肯定還沒有連接到有效的無線
ConnectivityManager.CONNECTIVITY_ACTION
這個監(jiān)聽網(wǎng)絡連接的設置,包括wifi和移動數(shù)據(jù)的打開和關(guān)閉。.
最好用的還是這個監(jiān)聽。wifi如果打開,關(guān)閉,以及連接上可用的連接都會接到監(jiān)聽。這個廣播的最大弊端是比上邊兩個廣播的反應要慢,如果只是要監(jiān)聽wifi,我覺得還是用上邊兩個配合比較合適。
至于這個ConnectivityManager,NetworkInfo是什么東西,別急,下面會大概介紹一下。
ConnectivityManager和NetworkInfo
ConnectivityManager主要用來干什么
怎樣獲取ConnectivityManager對象呢?
ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context .CONNECTIVITY_SERVICE);
獲取 NetworkInfo對象
主要有一下 幾種方法
綜上所述,我們?nèi)绻喇斍癕obile網(wǎng)絡或者WiFi網(wǎng)絡是否已經(jīng)連接上,總共有兩種方法。
第一種方法,只不過在 API23的時候已經(jīng) 過時了
State wifiState = null; State mobileState = null; ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context .CONNECTIVITY_SERVICE); wifiState = cm.getNetworkInfo(ConnectivityManager.TYPE_WIFI).getState(); mobileState = cm.getNetworkInfo(ConnectivityManager.TYPE_MOBILE).getState(); Log.d(TAG1, "wifi狀態(tài):" + wifiState + "\n mobile狀態(tài):" + mobileState); if (wifiState != null && mobileState != null && State.CONNECTED != wifiState && State.CONNECTED == mobileState) {// 手機網(wǎng)絡連接成功 Log.d(TAG1, "手機2g/3g/4g網(wǎng)絡連接成功"); APP.getInstance().setMobile(true); APP.getInstance().setWifi(false); APP.getInstance().setConnected(true); } else if (wifiState != null && State.CONNECTED == wifiState) {// 無線網(wǎng)絡連接成功 Log.d(TAG1, "無線網(wǎng)絡連接成功"); APP.getInstance().setMobile(false); APP.getInstance().setWifi(true); APP.getInstance().setConnected(true); } else if (wifiState != null && mobileState != null && State.CONNECTED != wifiState && State.CONNECTED != mobileState) {// 手機沒有任何的網(wǎng)絡 Log.d(TAG1, "手機沒有任何的網(wǎng)絡"); APP.getInstance().setMobile(false); APP.getInstance().setWifi(false); APP.getInstance().setConnected(false); }
第二種方法
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, "當前移動網(wǎng)絡連接可用 "); } } else { Log.e(TAG, "當前沒有網(wǎng)絡連接,請確保你已經(jīng)打開網(wǎng)絡 "); } } else { // not connected to the internet Log.e(TAG, "當前沒有網(wǎng)絡連接,請確保你已經(jīng)打開網(wǎng)絡 "); APP.getInstance().setWifi(false); APP.getInstance().setMobile(false); APP.getInstance().setConnected(false); }
網(wǎng)絡錯誤情況的處理
正如前面所提到的,這篇博客吧網(wǎng)絡錯誤主要分為兩大類
在這里 我們主要處理沒有網(wǎng)絡情況下的錯誤,現(xiàn)在 個人了解到 的主要有兩種處理方法。
第一種做法
在APP啟動的 時候檢查當前是否已經(jīng)連接上網(wǎng)絡,彈出一個對話框沒有的話跳轉(zhuǎn)到設置界面或者WiFi設置界面或者打開移動網(wǎng)絡界面 。
第二種方法
其實跟第一種做法差不多,只是在每一次 錯誤的情況下,都會判斷當前有沒有 網(wǎng)絡 ,沒有彈出一個對話框,跳轉(zhuǎn)到設置界面或者WiFi設置界面或者打開移動網(wǎng)絡界面 , 下面我們我們一起來看一下 怎樣彈出一個對話框,并且跳轉(zhuǎn)到相應的設置界面
這里我們采取第一種做法,效果圖如下
代碼如下
public static void showWifiDlg(final Context context) { AlertDialog.Builder builder = new AlertDialog.Builder(context.getApplicationContext()); if (mWifiDialog == null) { mWifiDialog = builder.setIcon(R.drawable.ic_launcher) // .setTitle("wifi設置") // .setMessage("當前無網(wǎng)絡").setPositiveButton("設置", new DialogInterface .OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // 跳轉(zhuǎn)到系統(tǒng)的網(wǎng)絡設置界面 Intent intent = null; // 先判斷當前系統(tǒng)版本 if (android.os.Build.VERSION.SDK_INT > 10) { // 3.0以上 intent = new Intent(android.provider.Settings .ACTION_WIFI_SETTINGS); } else { intent = new Intent(); intent.setClassName("com.android.settings", Settings.ACTION_WIFI_SETTINGS); } if ((context instanceof Application)) { intent.addFlags(FLAG_ACTIVITY_NEW_TASK); } context.startActivity(intent); } }).setNegativeButton("知道了", null).create(); // 設置為系統(tǒng)的Dialog,這樣使用Application的時候不會 報錯 mWifiDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT); } mWifiDialog.show(); }
這里對幾個 重要的 Action說一下
ACTION_DATA_ROAMING_SETTINGS: 跳轉(zhuǎn)到移動網(wǎng)絡設置界面
ACTION_WIFI_SETTINGS
Activity Action: Show settings to allow configuration of Wi-Fi.
ACTION_WIRELESS_SETTINGS
Activity Action: Show settings to allow configuration of wireless controls such as Wi-Fi, Bluetooth and Mobile networks.
關(guān)于更多Activity Action,請參考官網(wǎng)地址
需要注意的是
若我們 使用的Context不是Activity 的Context 而是Application的 Context,我們 需要做以下處理 ,否則會報錯
// 設置為系統(tǒng)級別的Dialog mWifiDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT); if ((context instanceof Application)) { intent.addFlags(FLAG_ACTIVITY_NEW_TASK); } context.startActivity(intent);
在AndroidMainFest中添加以下權(quán)限 。
智能無圖
智能無圖,這種瀏覽模式我們平時 很常見,比如在UC瀏覽器中,網(wǎng)易新聞中都有看到這種模式,這種模式的實質(zhì)就是監(jiān)聽網(wǎng)絡狀態(tài),再根據(jù)是否是WiFi去確定是否加載網(wǎng)絡圖片。
效果圖如下
我們可以看到在開啟智能無圖的情況下,若不是連接WiFi ,我們是不會去加載網(wǎng)絡圖片的。
實現(xiàn)的核心代碼如下
1)當智能無圖模式變化的時候,我們會把標志存進SharePreferences中
mSwitchWifiPic.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { SPUtils.put(SPConstants.isIntelligentNoPic,isChecked); } });
同時我們?yōu)榱诉M來的時候界面與SharePreferences中的 isIntelligentNoPic的值保持一致,我們需要調(diào)用一下代碼
boolean isIntelligentNoPic = SPUtils.getBoolean(SPConstants.isIntelligentNoPic); mSwitchWifiPic.setChecked(isIntelligentNoPic);
2)在NewsListAdapter中
// 是否開啟智能無圖模式,true表示開啟智能無圖模式 boolean isIntelligentNoPic = SPUtils.getBoolean(Constants.SPConstants.isIntelligentNoPic); WriteLogUtil.i("isIntelligentNoPic=" + isIntelligentNoPic); if (isIntelligentNoPic) { if (APP.getInstance().isWifi()) { GlideUtils.display(mContext, iv, picUrl); } else { iv.setImageDrawable(new ColorDrawable(Color.GRAY)); } } else { GlideUtils.display(mContext, iv, picUrl); }
至于APP.getInstance().isWifi()表示當前是否連接WiFi,是通過 監(jiān)聽廣播實現(xiàn)的 ,前面已經(jīng)說明了,這里就不再闡述了。
拓展工具類
public class NetStateUtils { /** * 判斷當前網(wǎng)絡是否是移動網(wǎng)絡 * * @param context * @return boolean */ public static boolean is3G(Context context) { ConnectivityManager connectivityManager = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); NetworkInfo activeNetInfo = connectivityManager.getActiveNetworkInfo(); if (activeNetInfo != null && activeNetInfo.getType() == ConnectivityManager.TYPE_MOBILE) { return true; } return false; } /** * 判斷當前網(wǎng)絡是否是wifi網(wǎng)絡 * * @param context * @return boolean */ public static boolean isWifi(Context context) { ConnectivityManager connectivityManager = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); NetworkInfo activeNetInfo = connectivityManager.getActiveNetworkInfo(); if (activeNetInfo != null && activeNetInfo.getType() == ConnectivityManager.TYPE_WIFI) { return true; } return false; } /** * 判斷當前網(wǎng)絡是否是2G網(wǎng)絡 * * @param context * @return boolean */ public static boolean is2G(Context context) { ConnectivityManager connectivityManager = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); NetworkInfo activeNetInfo = connectivityManager.getActiveNetworkInfo(); if (activeNetInfo != null && (activeNetInfo.getSubtype() == TelephonyManager.NETWORK_TYPE_EDGE || activeNetInfo.getSubtype() == TelephonyManager.NETWORK_TYPE_GPRS || activeNetInfo .getSubtype() == TelephonyManager.NETWORK_TYPE_CDMA)) { return true; } return false; } /** * wifi是否打開 */ public static boolean isWifiEnabled(Context context) { ConnectivityManager mgrConn = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); TelephonyManager mgrTel = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); return ((mgrConn.getActiveNetworkInfo() != null && mgrConn .getActiveNetworkInfo().getState() == NetworkInfo.State.CONNECTED) || mgrTel .getNetworkType() == TelephonyManager.NETWORK_TYPE_UMTS); } /** * 判斷是否有網(wǎng)絡連接 * * @param context * @return */ public static boolean isNetworkConnected(Context context) { if (context != null) { // 獲取手機所有連接管理對象(包括對wi-fi,net等連接的管理) ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context .CONNECTIVITY_SERVICE); // 獲取NetworkInfo對象 NetworkInfo networkInfo = manager.getActiveNetworkInfo(); //判斷NetworkInfo對象是否為空 if (networkInfo != null) return networkInfo.isAvailable(); } return false; } /** * 判斷MOBILE網(wǎng)絡是否可用 * * @param context * @param context * @return */ public static boolean isMobileConnected(Context context) { if (context != null) { //獲取手機所有連接管理對象(包括對wi-fi,net等連接的管理) ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context .CONNECTIVITY_SERVICE); //獲取NetworkInfo對象 NetworkInfo networkInfo = manager.getActiveNetworkInfo(); //判斷NetworkInfo對象是否為空 并且類型是否為MOBILE if (networkInfo != null && networkInfo.getType() == ConnectivityManager.TYPE_MOBILE) return networkInfo.isAvailable(); } return false; } /** * 獲取當前網(wǎng)絡連接的類型信息 * 原生 * * @param context * @return */ public static int getConnectedType(Context context) { if (context != null) { //獲取手機所有連接管理對象 ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context .CONNECTIVITY_SERVICE); //獲取NetworkInfo對象 NetworkInfo networkInfo = manager.getActiveNetworkInfo(); if (networkInfo != null && networkInfo.isAvailable()) { //返回NetworkInfo的類型 return networkInfo.getType(); } } return -1; } /** * 獲取當前的網(wǎng)絡狀態(tài) :沒有網(wǎng)絡-0:WIFI網(wǎng)絡1:4G網(wǎng)絡-4:3G網(wǎng)絡-3:2G網(wǎng)絡-2 * 自定義 * * @param context * @return */ public static int getAPNType(Context context) { //結(jié)果返回值 int netType = 0; //獲取手機所有連接管理對象 ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context .CONNECTIVITY_SERVICE); //獲取NetworkInfo對象 NetworkInfo networkInfo = manager.getActiveNetworkInfo(); //NetworkInfo對象為空 則代表沒有網(wǎng)絡 if (networkInfo == null) { return netType; } //否則 NetworkInfo對象不為空 則獲取該networkInfo的類型 int nType = networkInfo.getType(); if (nType == ConnectivityManager.TYPE_WIFI) { //WIFI netType = 1; } else if (nType == ConnectivityManager.TYPE_MOBILE) { int nSubType = networkInfo.getSubtype(); TelephonyManager telephonyManager = (TelephonyManager) context.getSystemService (Context.TELEPHONY_SERVICE); //3G 聯(lián)通的3G為UMTS或HSDPA 電信的3G為EVDO if (nSubType == TelephonyManager.NETWORK_TYPE_LTE && !telephonyManager.isNetworkRoaming()) { netType = 4; } else if (nSubType == TelephonyManager.NETWORK_TYPE_UMTS || nSubType == TelephonyManager.NETWORK_TYPE_HSDPA || nSubType == TelephonyManager.NETWORK_TYPE_EVDO_0 && !telephonyManager.isNetworkRoaming()) { netType = 3; //2G 移動和聯(lián)通的2G為GPRS或EGDE,電信的2G為CDMA } else if (nSubType == TelephonyManager.NETWORK_TYPE_GPRS || nSubType == TelephonyManager.NETWORK_TYPE_EDGE || nSubType == TelephonyManager.NETWORK_TYPE_CDMA && !telephonyManager.isNetworkRoaming()) { netType = 2; } else { netType = 2; } } return netType; } /** * 判斷GPS是否打開 * ACCESS_FINE_LOCATION權(quán)限 * * @param context * @return */ public static boolean isGPSEnabled(Context context) { //獲取手機所有連接LOCATION_SERVICE對象 LocationManager locationManager = ((LocationManager) context.getSystemService(Context .LOCATION_SERVICE)); return locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER); } /** * 獲得本機ip地址 * * @return */ public static String GetHostIp() { try { for (Enumerationen = NetworkInterface .getNetworkInterfaces(); en.hasMoreElements(); ) { NetworkInterface intf = en.nextElement(); for (Enumeration ipAddr = intf.getInetAddresses(); ipAddr .hasMoreElements(); ) { InetAddress inetAddress = ipAddr.nextElement(); if (!inetAddress.isLoopbackAddress()) { return inetAddress.getHostAddress(); } } } } catch (SocketException ex) { } catch (Exception e) { } return null; } /** * 獲取本機串號imei * * @param context * @return */ public static String getIMEI(Context context) { TelephonyManager telephonyManager = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); return telephonyManager.getDeviceId(); } /*** * 判斷是否有外網(wǎng)連接(普通方法不能判斷外網(wǎng)的網(wǎng)絡是否連接,比如連接上局域網(wǎng)) * * @return */ public static final boolean ping() { String result = null; try { String ip = "www.baidu.com";// ping 的地址,可以換成任何一種可靠的外網(wǎng) Process p = Runtime.getRuntime().exec("ping -c 3 -w 100 " + ip);// ping網(wǎng)址3次 // 讀取ping的內(nèi)容,可以不加 InputStream input = p.getInputStream(); BufferedReader in = new BufferedReader(new InputStreamReader(input)); StringBuffer stringBuffer = new StringBuffer(); String content = ""; while ((content = in.readLine()) != null) { stringBuffer.append(content); } Log.d("------ping-----", "result content : " + stringBuffer.toString()); // ping的狀態(tài) int status = p.waitFor(); if (status == 0) { result = "success"; return true; } else { result = "failed"; } } catch (IOException e) { result = "IOException"; } catch (InterruptedException e) { result = "InterruptedException"; } finally { Log.d("----result---", "result = " + result); } return false; } }
源碼下載地址:https://github.com/gdutxiaoxu/FunAPP.git
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。