最近在写项目的时候由于联网用得比较频繁,就简单地封装了一个工具类,省得每次联网得时候都要把联网配置写一遍,代码如下:
public class okhttp_plus {
public static String responseDate = "";
public static String sendRequestwithOkHttp(final String url, final RequestBody requestBody, final Context context) {
//开启现线程发起网络请求
new Thread(new Runnable() {
@Override
public void run() {
try {
OkHttpClient client = new OkHttpClient.Builder()
.retryOnConnectionFailure(true)
.connectTimeout(10, TimeUnit.SECONDS)
.readTimeout(10, TimeUnit.SECONDS)
.build(); Request request = new Request.Builder()
.post(requestBody)
.addHeader("Connection","close")
.addHeader("Content-Type","application/x-www-form-urlencoded")
.url(url) //网址有待改动
.build(); Call call = client.newCall(request);
responseDate = "";
try {
Response response = call.execute();
responseDate = response.body().string();
Log.d("ZGH", "这是工具类里面的responsedata"+responseDate);
} catch (final Exception e) {
e.printStackTrace();
if (e instanceof SocketTimeoutException) {
Toast.makeText(context, "连接超时", Toast.LENGTH_SHORT).show();
}
if (e instanceof ConnectException) {
Toast.makeText(context, "连接异常", Toast.LENGTH_SHORT).show();
} if (e instanceof ProtocolException) {
Toast.makeText(context, "未知异常,请稍后再试", Toast.LENGTH_SHORT).show();
}
} } catch (Exception e) {
e.printStackTrace();
}
}
}).start(); return responseDate;
}
}
但是这个方法总是出现log打印出来的responsedata是正常的,但是返回值里面的responsedata确是空,百思不得其解,在网上查了各种资料也没有关于这种情况得记录,终于在崩溃的边缘想起了这个方法里面新开了一个线程,而多线程的执行是同步的,所以主线程肯定是没等到联网线程返回结果就将responsdata返回了,所以肯定是返回空值了,问题找出来之后,怎么解决也是想了一会,最终我在返回值前面加了一个while循环,代码如下:
//while循环用于等待网络线程返回response
while (responseDate.equals("")){
}
while循环先判断一下返回值是否为空,如果为空就表示联网请求还未完成,一直到responsedata不为空才向下执行,问题解决。
=============================================================
数月之后想起来博客忘记改了,不能用while循环判断,因为如果联网失败的话,while就会变成死循环,倒是app出现无响应的情况!!!希望没有误导到别人。。。