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