简单的封装了一个OKHttp网络请求工具类,直接粘贴进去调用使用,很方便
来源:互联网 发布:矩阵怎么输 matlab 编辑:程序博客网 时间:2024/04/28 03:34
谢谢您尊重他人的劳动成果:
http://blog.csdn.net/w630886916/article/details/53431525
简单的封装了一个OKHttp网络请求工具类,直接粘贴进去调用使用,很方便。
首先这个是基于OKHttp 写的网络请求工具类,所以要导入okHttp的一个jar包。
用android Studio,可以导包,或者直接在build里面添加一句代码:
dependencies {compile 'com.squareup.okhttp3:logging-interceptor:3.4.1'}
这里有一个注意点:
/** * 如果是用的3.0之前的版本 使用以下直接设置连接超时.读取超时,写入超时 */ //client.setConnectTimeout(10, TimeUnit.SECONDS); //client.setWriteTimeout(10, TimeUnit.SECONDS); //client.setReadTimeout(30, TimeUnit.SECONDS);
当然,在工具类也有标明和注释,仔细看看就明白了。
其实也是为了以后自己省事而已。
jar包直接搜索一下就好,哪里都是。
下面
直接上干货:
import android.os.Handler;import android.os.Looper;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;import java.util.HashMap;import java.util.Map;import java.util.concurrent.TimeUnit;import okhttp3.Call;import okhttp3.Callback;import okhttp3.FormBody;import okhttp3.OkHttpClient;import okhttp3.Request;import okhttp3.RequestBody;import okhttp3.Response;import okhttp3.logging.HttpLoggingInterceptor;/** * Created by fan on 2016/11/9. */public class OkHttp { /** * 静态实例 */ private static OkHttp sOkHttpManager; /** * okhttpclient实例 */ private OkHttpClient mClient; /** * 因为我们请求数据一般都是子线程中请求,在这里我们使用了handler */ private Handler mHandler; /** * 构造方法 */ private OkHttp() { // 可以通过实现 Logger 接口更改日志保存位置 HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor(); loggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY);// mClient = new OkHttpClient.Builder().addInterceptor(loggingInterceptor).build(); mClient = new OkHttpClient(); /** * 在这里直接设置连接超时.读取超时,写入超时 */ OkHttpClient.Builder builder = mClient.newBuilder(); builder.connectTimeout(10, TimeUnit.SECONDS); builder.readTimeout(10, TimeUnit.SECONDS); builder.writeTimeout(10, TimeUnit.SECONDS); builder.addInterceptor(loggingInterceptor); mClient = builder.build(); /** * 如果是用的3.0之前的版本 使用以下直接设置连接超时.读取超时,写入超时 */ //client.setConnectTimeout(10, TimeUnit.SECONDS); //client.setWriteTimeout(10, TimeUnit.SECONDS); //client.setReadTimeout(30, TimeUnit.SECONDS); /** * 初始化handler */ mHandler = new Handler(Looper.getMainLooper()); } /** * 单例模式 获取OkHttp实例 * * @return */ public static OkHttp getInstance() { if (sOkHttpManager == null) { sOkHttpManager = new OkHttp(); } return sOkHttpManager; } //-------------------------同步的方式请求数据-------------------------- /** * 对外提供的get方法,同步的方式 * * @param url 传入的地址 * @return */ public static Response getSync(String url) { //通过获取到的实例来调用内部方法 return sOkHttpManager.inner_getSync(url); } /** * GET方式请求的内部逻辑处理方式,同步的方式 * * @param url * @return */ private Response inner_getSync(String url) { Request request = new Request.Builder().url(url).build(); Response response = null; try { //同步请求返回的是response对象 response = mClient.newCall(request).execute(); } catch (IOException e) { e.printStackTrace(); } return response; } /** * 对外提供的同步获取String的方法 * * @param url * @return */ public static String getSyncString(String url) { return sOkHttpManager.inner_getSyncString(url); } /** * 同步方法 */ private String inner_getSyncString(String url) { String result = null; try { /** * 把取得到的结果转为字符串,这里最好用string() */ result = inner_getSync(url).body().string(); } catch (IOException e) { e.printStackTrace(); } return result; } //-------------------------异步的方式请求数据-------------------------- public static void getAsync(String url, DataCallBack callBack) { getInstance().inner_getAsync(url, callBack); } /** * 内部逻辑请求的方法 * * @param url * @param callBack * @return */ private void inner_getAsync(String url, final DataCallBack callBack) { final Request request = new Request.Builder().url(url).build(); mClient.newCall(request).enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { deliverDataFailure(request, e, callBack); } @Override public void onResponse(Call call, Response response) throws IOException { String result = null; try { result = response.body().string(); } catch (IOException e) { deliverDataFailure(request, e, callBack); } deliverDataSuccess(result, callBack); } }); } /** * 分发失败的时候调用 * * @param request * @param e * @param callBack */ private void deliverDataFailure(final Request request, final IOException e, final DataCallBack callBack) { /** * 在这里使用异步处理 */ mHandler.post(new Runnable() { @Override public void run() { if (callBack != null) { callBack.requestFailure(request, e); } } }); } /** * 分发成功的时候调用 * * @param result * @param callBack */ private void deliverDataSuccess(final String result, final DataCallBack callBack) { /** * 在这里使用异步线程处理 */ mHandler.post(new Runnable() { @Override public void run() { if (callBack != null) { try { callBack.requestSuccess(result); } catch (Exception e) { e.printStackTrace(); } } } }); } /** * 数据回调接口 */ public interface DataCallBack { void requestFailure(Request request, IOException e); void requestSuccess(String result) throws Exception; } //-------------------------提交表单-------------------------- public static void postAsync(String url, Map<String, String> params, DataCallBack callBack) { getInstance().inner_postAsync(url, params, callBack); } private void inner_postAsync(String url, Map<String, String> params, final DataCallBack callBack) { RequestBody requestBody = null; if (params == null) { params = new HashMap<>(); } /** * 如果是3.0之前版本的,构建表单数据是下面的一句 */ //FormEncodingBuilder builder = new FormEncodingBuilder(); /** * 3.0之后版本 */ FormBody.Builder builder = new FormBody.Builder(); /** * 在这对添加的参数进行遍历,map遍历有四种方式,如果想要了解的可以网上查找 */ for (Map.Entry<String, String> map : params.entrySet()) { String key = map.getKey().toString(); String value = null; /** * 判断值是否是空的 */ if (map.getValue() == null) { value = ""; } else { value = map.getValue(); } /** * 把key和value添加到formbody中 */ builder.add(key, value); } requestBody = builder.build(); //结果返回 // 请求对象 final Request request = new Request.Builder().url(url).post(requestBody).build(); mClient.newCall(request).enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { deliverDataFailure(request, e, callBack); } @Override public void onResponse(Call call, Response response) throws IOException { String result = response.body().string(); deliverDataSuccess(result, callBack); } }); } //-------------------------文件下载-------------------------- public static void downloadAsync(String url, String desDir, DataCallBack callBack) { getInstance().inner_downloadAsync(url, desDir, callBack); } /** * 下载文件的内部逻辑处理类 * * @param url 下载地址 * @param desDir 目标地址 * @param callBack */ private void inner_downloadAsync(final String url, final String desDir, final DataCallBack callBack) { final Request request = new Request.Builder().url(url).build(); mClient.newCall(request).enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { deliverDataFailure(request, e, callBack); } @Override public void onResponse(Call call, Response response) throws IOException { /** * 在这里进行文件的下载处理 */ InputStream inputStream = null; FileOutputStream fileOutputStream = null; try { //文件名和目标地址 File file = new File(desDir, getFileName(url)); //把请求回来的response对象装换为字节流 inputStream = response.body().byteStream(); fileOutputStream = new FileOutputStream(file); int len = 0; byte[] bytes = new byte[2048]; //循环读取数据 while ((len = inputStream.read(bytes)) != -1) { fileOutputStream.write(bytes, 0, len); } //关闭文件输出流 fileOutputStream.flush(); //调用分发数据成功的方法 deliverDataSuccess(file.getAbsolutePath(), callBack); } catch (IOException e) { //如果失败,调用此方法 deliverDataFailure(request, e, callBack); e.printStackTrace(); } finally { if (inputStream != null) { inputStream.close(); } if (fileOutputStream != null) { fileOutputStream.close(); } } } }); } /** * 根据文件url获取文件的路径名字 * * @param url * @return */ private String getFileName(String url) { int separatorIndex = url.lastIndexOf("/"); String path = (separatorIndex < 0) ? url : url.substring(separatorIndex + 1, url.length()); return path; }}
完毕
以下也附上java文件。
点击下载:java工具类
点击下载okhttp 3.4.1版
0 0
- 简单的封装了一个OKHttp网络请求工具类,直接粘贴进去调用使用,很方便
- 自己封装了一个Okhttp网络请求,操作简单,可区分一个类中的不同请求
- okHttp封装,使用超简单的网络请求实现
- OKhttp的封装工具类(可以直接使用)
- 自己简单的封装一个OKHttp工具类
- Okhttp网络请求的封装类
- 封装OkHttp的网络请求
- okhttp网络请求框架的简单使用
- OkHttp网络请求封装类
- 以OKHttp为基础封装网络请求工具类
- 简单实现RxJava2+Okhttp+Retrofit2的网络请求框架封装
- 非常简单的OKhttp封装工具类
- 简单封装okHttp网络请求框架
- 使用AF的一个简单网络请求封装+ (instancetype)sharedInstance;
- Okhttp 简单的网络封装
- 安卓网络请求框架okHttp的使用与封装
- 网络请求封装及使用(okhttp)
- OKHttp网络请求封装
- 【AI每日播报】亚马逊发布多项AI云服务 魅族初试人工智能化系统
- 连续吃能防肿瘤
- Scratch:让孩子们在实现创意中,理解编程概念
- 进制转换
- CentOS 大米云服务器服务器搭建笔记
- 简单的封装了一个OKHttp网络请求工具类,直接粘贴进去调用使用,很方便
- app上架因为副标题被App Store残忍拒绝!
- caffe卷积原理
- Lightoj1084【DP啊DP】
- Console命令详解,让调试js代码变得更简单
- MAC中如何配置环境变量
- SpringIoC容器
- 错误"数据库的事务日志已满。若要查明无法重用日志中的空间的原因"的解决方法
- [总结]虚拟机VMware10.0+Ubuntu14.04+opencv+Ros+pcl+OpenNI+g2o+DSO+Pangolin+win7(Ubuntu双系统)安装过程整理