1. 程式人生 > >OkHttp解析json,使用方法

OkHttp解析json,使用方法



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;
    }






相關推薦

OkHttp解析json,使用方法

import android.os.Handler; import android.os.Looper; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.Inpu

使用okhttp 解析json資料

 okhttp還是挺好使用的,而且6.0版本里面已經不提倡使用了HttpClient,下面我們來說說okhttp的使用 1.我們在Android studio中新增對okhttp的依賴(本文是在建立在

C# 解析JSON方法總結

主要參考http://blog.csdn.net/joyhen/article/details/24805899和http://www.cnblogs.com/yanweidie/p/4605212.html 根據自己需求,做些測試、修改、整理。 一、用JsonConve

JavaScript中使用eval()方法解析json

括號 javascrip pass 後臺 {} ava eval() 一個 java 最近在js用到了eval()方法,在這裏做個筆記 當時是這麽用的:data = eval("("+data+")"); data為後臺向前臺傳送的一個json串,所以這裏需要使用eva

ASP解析Json最簡單的方法

.get .proto val json his 解析 字符 json字符串 解析json <% Dim json, obj json = "{a:""aaa"", b:{ name:""bb"", value:""text"" }, c:[""

QT使用QJson生成解析Json資料的方法

QT中使用json還是比較方便的,下面用例子直接說明 舉例子之前首先推薦一個線上解析json格式的網站,具體格式用法如下圖所示: 之後根據這個格式進行json資料解析。 QT使用json需要包含的標頭檔案 #include<qjsondocument.h> #include<qj

QT使用QJson生成解析Json數據的方法

.cn 元素 details mdt toa bytearray ble json生成 判斷 QT中使用json還是比較方便的,下面用例子直接說明 舉例子之前首先推薦一個在線解析json格式的網站,具體格式用法如下圖所示: 之後根據這個格式進行json數據解析。 QT使用

java解析json(二) 解析json方法介紹

解析json的方法有很多種,常用的有三種,分別是json官方自帶的jon解析工具,阿里出品的解析工具,還有產自谷歌的解析工具。 接下來開始逐一介紹這三款工具。 (一) 官方自帶的json工具JsonObject 和就JasonArray 如果只是簡單一個json 字串,

android Gson解析JSON資料中動態未知欄位key的方法

有時在解析json資料中的欄位key是動態可變的時候,由於Gson是使用靜態註解的方式來設定實體物件的,因此我們很難直接對返回的型別來判斷。但Gson在解析過程中如果不知道解析的欄位,就會將所有變數儲存在一個Map中,我們只要例項化這個map就能動態地取出key和value了。先給出一段js

springboot新增fastjson第三方json解析工具方法(預設jackjson)

pom.xml新增配置資訊 父級標籤為dependencies <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> &

Gson解析JSON資料中動態未知欄位key的方法

有時在解析json資料中的欄位key是動態可變的時候,由於Gson是使用靜態註解的方式來設定實體物件的,因此我們很難直接對返回的型別來判斷。但Gson在解析過程中如果不知道解析的欄位,就會將所有變數儲存在一個Map中,我們只要例項化這個map就能動態地取出key

使用Gson解析json在打包混淆時出錯的解決方法

解決android使用gson解析json字串,並使用混淆編譯方式打包apk遇到的問題 方法一: Gson gson = new Gson(); // 將json格式字串轉化為List<物件> Type listType = new TypeToken<ArrayList<Person

asp讀取解析JSON的幾種方法

方法一(使用MSScriptControl.ScriptControl): <% Dim sc4Json,arr0,json InitScriptControl json="{""name"":""123"",""content"":[{""id"":""1""}

C#解析json檔案的方法

C# 解析 json   JSON(全稱為JavaScript Object Notation) 是一種輕量級的資料交換格式。它是基於JavaScript語法標準的一個子集。 JSON採用完全獨立於語言的文字格式,可以很容易在各種網路、平臺和程式之間傳輸。JS

解析Json之MappingJackson2HttpMessageConverter使用方法

眾所周知,用Spring cloud構建微服務架構時,後臺接收controller通常用@RestController註解。@Restcontroller是@Controller和@ResponseBody的結合體。這樣就將後臺返回的Java物件轉換為Json字串傳遞給前臺,

解析json字串,根據key得到對應的value的方法

最近公司的專案,寫了個傳入json字串和要獲取的key,返回相應value的方法。 public String jxJson(String mkey, String strJson) { String value = "";

兩種方法解析Json陣列

解析的Json陣列如下: 第一種 使用自帶的JsonArray 解析,程式碼如下: //通過自帶的JsonArray public List<Person> getListPerson

C++ 解析Json(jsoncpp)使用方法

JSON(JavaScript Object Notation) 是一種輕量級的資料交換格式,和xml類似,本文主要對VS2008中使用Jsoncpp解析json的方法做一下記錄。Jsoncpp是個跨平臺的開源庫,下載地址:http://sourceforge.net/p

js 解析json 常用方法 --前端與後端的互動(前端)

(1)前端js解析前端json資料: one: javascript定義json物件變數: var jsonobject={};//可以不使用宣告,推薦宣告一下,嚴格一些,最好使用嚴格模式 賦值json物件的key-value值: jsonobject[key]=v

delphi解析json資料的方法

function TFrm_Main.getquery: string;  var   vjson:ISuperObject;     //Vitem   s1,s2:string;   PathStr:string;   ch,ph:string;   i,j:integer;   mylist:TStri