Android之通过HttpURLConnection.getResponseCode状态码抛出异常的问题以及解决方法

本文介绍了如何解决Android应用中出现的NetworkOnMainThreadException异常。通过分析错误信息和使用多线程技术,最终解决了主线程中执行网络请求的问题。

1.最近,在学习解析json数据的时候遇到一个错误信息,错误信息如下图所示:

 
发现解析出来的数据为空,错误信息如上图所示,发现程序中的HttpUtils工具类的22行出现了错误和MainActivity类的onClick方法的52出现了错误,因此我去寻找了一下这两个类报错的所在行,看看是否代码写错,因为我也是学习的,所以代码写错也很正常。
2.HttpUtils类的22行代码如下图所示:
 
发现并没有写错方法,再看下MainActivity类的onClick方法的52行,如下图所示:
 
发现这行代码竟是调用上面的那个HttpUtils类的getJsonContent(url_path)方法,那我觉得应该是上面通过HttpURLConnection访问网络请求可能出现错误,于是我上网查找资料,经过测试这些代码都没问题。
3.那么问题出现在哪里呢?其实我们找到了代码报异常的地方,但是我们并没有把完整打印在Log的异常信息看全,我再次附上Log所打印的错误信息,一看便明白了,如下图所示:
 
如上图所示,报错的异常为Android.os.NetworkOnMainThreadException异常,意思是安卓操作系统的网络工作在主线程异常,就是在网络通信中在主线程工作中的异常,所以必须在另一个线程工作,所以,上述的代码没问题,问题在于HttpUtils类的getJsonContent(url_path)方法时对网络进行操作不能在主线程里进行调用,必须新建一个线程进行网络操作,因此,我们必须在MainActivity类的onClick()方法调用那个getJsonContent(url_path)方法里用一个新线程来访问,进行网络通信。
4.所以,我们开启一个新线程,这个新线程专门来处理对访问网络,进行网络通信工作的那个方法。即使用多线程的方法,因此,MainActivity类中的那个onClick()方法中的52行可改为如下图所示,即可:
 
这样有时还会报同样的错误,此时就该在线程中利用Handle消息机制进行处理。
package com.example.myapplication; import android.util.Log; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.HttpURLConnection; import java.net.URL; import java.util.logging.Level; import java.util.logging.Logger; public class NetUtil { public static final String URL_BEMFA = "https://apis.bemfa.com/va/getmsg?uid=c5d604eb9c3d46d5803b4a6d0dd427bc&topic=sensors&type=3"; public static String doGet(String urlStr) { String result = ""; HttpURLConnection connection = null; InputStreamReader inputStreamReader = null; BufferedReader bufferedReader = null; // 连接网络 try { URL url = new URL(urlStr); connection = (HttpURLConnection) url.openConnection(); connection.setRequestMethod("GET"); // Log.d("NetUtil", "Request Method: " + connection.getRequestMethod()); connection.setConnectTimeout(5000); // 获取响应码 int responseCode = connection.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { // 从连接中读取数据(二进制) InputStream inputStream = connection.getInputStream(); inputStreamReader = new InputStreamReader(inputStream); // 二进制流送入缓冲区 bufferedReader = new BufferedReader(inputStreamReader); // 从缓存区中一行行读取字符串 StringBuilder stringBuilder = new StringBuilder(); String line = ""; while ((line = bufferedReader.readLine()) != null) { stringBuilder.append(line); } result = stringBuilder.toString(); } else { Log.e("NetUtil", "HTTP request failed with status code: " + responseCode); } } catch (Exception e) { e.printStackTrace(); Log.e("NetUtil", "HTTP request failed: " + e.getMessage()); } finally { if (connection != null) { connection.disconnect(); } if (inputStreamReader != null) { try { inputStreamReader.close(); } catch (IOException e) { e.printStackTrace(); } } if (bufferedReader != null) { try { bufferedReader.close(); } catch (IOException e) { e.printStackTrace(); } } } return result; } public static String getBemfaData() { // 拼接出获取数据的URL String bemfaUrl = URL_BEMFA; Log.d("fan", "----bemfaUrl----" + bemfaUrl); String bemfaResult = doGet(bemfaUrl); Log.d("fan", "----bemfaResult----" + bemfaResult); return bemfaResult; } public static String doPost(String urlStr, String json) { String result = ""; HttpURLConnection connection = null; OutputStream outputStream = null; try { URL url = new URL(urlStr); connection = (HttpURLConnection) url.openConnection(); connection.setRequestMethod("POST"); connection.setDoOutput(true); connection.setRequestProperty("Content-Type", "application/json"); connection.setConnectTimeout(5000); outputStream = connection.getOutputStream(); outputStream.write(json.getBytes()); outputStream.flush(); int responseCode = connection.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { InputStream inputStream = connection.getInputStream(); InputStreamReader inputStreamReader = new InputStreamReader(inputStream); BufferedReader bufferedReader = new BufferedReader(inputStreamReader); StringBuilder stringBuilder = new StringBuilder(); String line; while ((line = bufferedReader.readLine()) != null) { stringBuilder.append(line); } result = stringBuilder.toString(); } else { Logger.getLogger(NetUtil.class.getName()).log(Level.SEVERE, "HTTP request failed with status code: {0}", responseCode); } } catch (Exception e) { Logger.getLogger(NetUtil.class.getName()).log(Level.SEVERE, "HTTP request failed: {0}", e.getMessage()); } finally { if (connection != null) { connection.disconnect(); } if (outputStream != null) { try { outputStream.close(); } catch (IOException e) { Logger.getLogger(NetUtil.class.getName()).log(Level.SEVERE, "Failed to close output stream", e); } } } return result; } } E HTTP request failed with status code: {0}怎么解决
最新发布
06-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值