okHttps3请求网络工具类

注意点:

  • okhttp2.x和okhttp3中的回调都不是在UI线程中。
  • okhttp3同步请求: mOkHttpClient.newCall(request).execute();
  • okhttp3异步请求:mOkHttpClient.newCall(request).enqueue();
  • 本工具类是对okhttp3基本请求的封装,而OkHttpFinal对okhttp进行了较为完善的封装,关于OkHttpFinal,可以参考链接: https://github.com/pengjianbo/OkHttpFinal

import java.io.IOException;
import java.util.Map;
import java.util.concurrent.TimeUnit;

import okhttp3.Callback;
import okhttp3.FormBody;
import okhttp3.MediaType;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody;
import okhttp3.Response;
import android.os.Handler;
import android.os.Looper;
import android.util.Log;


/**
 * okhttp请求
 *
 */
public class HttpUtils {

    private OkHttpClient client;
    // 超时时间
    public static final int TIMEOUT = 1000 * 60;

    //json请求
    public static final MediaType JSON = MediaType
            .parse("application/json; charset=utf-8");

    private Handler handler = new Handler(Looper.getMainLooper());

    public HttpUtils() {
        this.init();
    }

    private void init() {

        client = new OkHttpClient();

        // 设置超时时间
        client.newBuilder().connectTimeout(TIMEOUT, TimeUnit.SECONDS)
                .writeTimeout(TIMEOUT, TimeUnit.SECONDS)
                .readTimeout(TIMEOUT, TimeUnit.SECONDS).build();

    }

    /**
     * post请求,json数据为body
     * 
     * [@param] url
     * [@param]Json
     * [@param]callback
     */
    public void postJson(String url, String json, final HttpCallback callback) {

        RequestBody body = RequestBody.create(JSON, json);
        Request request = new Request.Builder().url(url).post(body).build();

        client.newCall(request).enqueue(new Callback() {

            [@Override]
            public void onResponse(Response response) throws IOException {
                // TODO Auto-generated method stub

                if (response.isSuccessful()) {
                    onSuccess(callback, response.body().string());
                } else {
                    onError(callback, response.message());
                }
            }

            [@Override]
            public void onFailure(Request arg0, IOException arg1) {
                // TODO Auto-generated method stub

                onError(callback, arg1.getMessage());
                arg1.printStackTrace();

            }
        });

    }

    /**
     * post请求 map为body
     * 
     * @param url
     * @param map
     * @param callback
     */
    public void post(String url, Map<String, Object> map,final HttpCallback callback) {

        /**
         * 创建请求的参数body
         */
        FormBody.Builder builder = new FormBody.Builder();

        /**
         * 遍历key
         */
        if (null != map) {
            for (Map.Entry<String, Object> entry : map.entrySet()) {

                builder.add(entry.getKey(), entry.getValue().toString());

            }
        }

        RequestBody body = builder.build();

        Request request = new Request.Builder().url(url).post(body).build();

        client.newCall(request).enqueue(new Callback() {

            @Override
            public void onResponse(final Response response) throws IOException {
                // TODO Auto-generated method stub

                if (response.isSuccessful()) {

                    onSuccess(callback, response.body().string());

                } else {
                    onError(callback, response.message());
                }
            }

            @Override
            public void onFailure(Request arg0, IOException arg1) {
                // TODO Auto-generated method stub
                arg1.printStackTrace();
                onError(callback, arg1.getMessage());
            }
        });

    }

    /**
     * get请求
     * @param url
     * @param callback
     */
    public void get(String url, final HttpCallback callback) {

        Request request = new Request.Builder().url(url).build();

        client.newCall(request).enqueue(new Callback() {

            @Override
            public void onResponse(Response response) throws IOException {
                // TODO Auto-generated method stub
                if (response.isSuccessful()) {
                    onSuccess(callback, response.body().string());
                } else {
                    onError(callback, response.message());
                }
            }

            @Override
            public void onFailure(Request arg0, IOException arg1) {
                // TODO Auto-generated method stub

                onError(callback, arg1.getMessage());
                arg1.printStackTrace();

            }
        });

    }


    private void onSuccess(final HttpCallback callback, final String data) {

        debug(data);

        if (null != callback) {
            handler.post(new Runnable() {
                public void run() {
                    callback.onSuccess(data);
                }
            });
        }
    }

    private void onError(final HttpCallback callback,final String msg) {
        if (null != callback) {
            handler.post(new Runnable() {
                    public void run() {
                        callback.onError(msg);
                    }
                });
        }
    }


    /**
     * http请求回调
     * 
     * @author Flyjun
     *
     */
    public static abstract class HttpCallback {

        // 成功回调
        public abstract void onSuccess(String data);

        // 失败回调
        public void onError(String msg) {};
    }


}

转载于:https://my.oschina.net/fltsp/blog/1477085

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Postman 4.9.3 是一种用于测试、调试和管理 API 的工具。它是一个功能强大的软件包,为开发者提供了一个直观且易于使用的界面,以便构建和测试自己的 API。 Postman 4.9.3 的最显著特点之一是它支持多种常见的 API 协议和数据格式,包括 HTTP、HTTPS、REST、SOAP、GraphQL、URL 编码、JSON 和 XML 等。这使开发者能够轻松地与多种类型的 API 进行交互并测试其功能。 此外,Postman 4.9.3 还提供了一套丰富的功能,用于创建和管理 API 测试集合。开发者可以使用 Postman 接口构建器来定义自己的请求和响应,并可以将这些请求和响应组合成测试集合,以便在整个开发过程中进行自动化测试。 Postman 还具有强大的协作功能,开发者可以与团队中的其他成员共享测试集合、环境和变量。这使得团队能够更加高效地协同工作,共同开发和测试 API。 最后,Postman 4.9.3 还有一个广泛的插件生态系统,提供了各种各样的扩展,以满足不同开发者的需求。这些插件可以增加 Postman 的功能和灵活性,使其更适应不同的开发环境和需求。 总之,Postman 4.9.3 是一款功能强大、易于使用和高度可定制的 API 测试工具,提供了丰富的功能和协作工具,以满足开发者在构建、测试和管理 API 方面的需求。它已成为许多开发者和团队的首选工具,用于加快开发周期并提高 API 的质量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值