okhttp3源碼
❶ okhttp框架緩存問題,okhttp3無法使用okhttpclient.cache().get()來獲取response 求解!
OkHttp是一個相對成熟的解決方案,據說Android4.4的源碼中可以看到HttpURLConnection已經替換成OkHttp實現了。所以我們更有理由相信OkHttp的強大。
OkHttp 處理了很多網路疑難雜症:會從很多常用的連接問題中自動恢復。如果您的伺服器配置了多個IP地址,當第一個IP連接失敗的時候,OkHttp會自動嘗試下一個IP。OkHttp還處理了代理伺服器問題和SSL握手失敗問題。
使用 OkHttp 無需重寫您程序中的網路代碼。OkHttp實現了幾乎和java.net.HttpURLConnection一樣的API。如果你用了 Apache HttpClient,則OkHttp也提供了一個對應的okhttp-apache 模塊。
❷ OkHttp3幾個簡單的例子和在子線程更新UI線
在子線程中更新UI:由於安卓更新UI元素必須在主線程中,否則就會出現異常。有時候我們必須在子線程里去執行一些耗時任務,然後根據任務的執行結果來更新相應的UI控制項,比如:執行網路請求,需要將傳回的數據更新到UI上。
操作方法:
一、在主線程中new出Handler的實例handler,在Handler的handleMessage()方法中傳回的Message對象屬性進行判斷,當滿足要求時,執行UI更新的操作。
在子線程的run()方法內,1、實例化Message對象message;2、對象調用Message的what變數,設置message的屬性;3、對象調用sendMessage()方法,將Message對象發送出去。
private Handler handler = new Handler() {
public void handleMessage(Message msg) {
switch (msg.what) {
case UPDATE_TEXT:
// 在這里可以進行UI操作
text.setText("Nice to meet you");
break;
default:
break;
}
}
new Thread(new Runnable() {
@Override
public void run() {
Message message = new Message();
message.what = UPDATE_TEXT;
handler.sendMessage(message); // 將Message對象發送出去
}
}).start();
❸ okhttp3使用詳解get怎麼傳參數
kHttp 可以做很多事,包括上傳字元串、上傳文件、上傳流、上傳表格參數、上傳多部分的請求、響應 Json、響應緩存等。目前主要流行 Json 數據通信,所以我們就來講講基於 Json 通信的 GET 和 POST 請求與響應。
2 下載 OkHttp
介紹了這么多理論知識,接下來就進入實戰階段了,首先下載 OkHttp 的 jar 包,可以去 GitHub 下載最近的包。
這是最新下載地址:https://search.maven.org/remote_content?g=com.squareup.okhttp3&a=okhttp&v=LATEST
當然,你也可以在項目中直接添加編譯(用於 Android Studio):compile 'com.squareup.okhttp3:okhttp:3.2.0'
OkHttp 的項目地址:https://github.com/square/okhttp
除此之外,還需要添加一個 OkHttp 的依賴包:okio.jar,下載地址:https://search.maven.org/remote_content?g=com.squareup.okio&a=okio&v=LATEST
項目地址:https://github.com/square/okio
編譯地址:compile 'com.squareup.okio:okio:1.6.0'
3 GET 請求
我們從最簡單的 Http 請求開始學起,首先需要獲取一個 OkHttpClient 對象,方法如下:
[java] view plain print?
❹ github類似okhttp源碼怎樣看
Android中在使用OkHttp這個庫的時候,有時候需要持久化Cookie,那麼怎麼實現呢。OkHttp的內部源碼過於復雜,不進行深究,這里只看其中的HttpEngineer裡面的部分源碼,在發起請求以及請求結束都會調用這個類的幾個方法。
❺ 關於okhttp3和HttpURLConnection的一些問題
從Android 4.4起, 其HttpURLConnection的內部實現已經變為OkHttp
❻ okhttp3怎麼設置緩存
OkHttp是一個相對成熟的解決方案,據說Android4.4的源碼中可以看到HttpURLConnection已經替換成OkHttp實現了。所以我們更有理由相信OkHttp的強大。
OkHttp 處理了很多網路疑難雜症:會從很多常用的連接問題中自動恢復。如果您的伺服器配置了多個IP地址,當第一個IP連接失敗的時候,OkHttp會自動嘗試下一個IP。OkHttp還處理了代理伺服器問題和SSL握手失敗問題。
使用 OkHttp 無需重寫您程序中的網路代碼。OkHttp實現了幾乎和java.net.HttpURLConnection一樣的API。如果你用了 Apache HttpClient,則OkHttp也提供了一個對應的okhttp-apache 模塊。
❼ java okhttp3 的使用方法
代碼如下:
importjava.io.IOException;
importjava.net.SocketTimeoutException;
importjava.util.ArrayList;
importjava.util.HashMap;
importjava.util.List;
importjava.util.Map;
importokhttp3.Cookie;
importokhttp3.CookieJar;
importokhttp3.FormBody;
importokhttp3.Headers;
importokhttp3.HttpUrl;
importokhttp3.MediaType;
importokhttp3.OkHttpClient;
importokhttp3.Request;
importokhttp3.RequestBody;
importokhttp3.Response;
importokhttp3.OkHttpClient.Builder;
publicclassHttpLib{
publicstaticbooleandebug=false;
="Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/63.0.3239.108Safari/537.36";
privateMap<String,List<Cookie>>cookieContainer=newHashMap<String,List<Cookie>>();
privatebooleanenableCookie=false;
publicbooleanisEnableCookie(){
returnenableCookie;
}
publicvoidsetEnableCookie(booleanenableCookie){
this.enableCookie=enableCookie;
}
publicStringget(Stringurl)throwsSocketTimeoutException{
returnget(url,null);
}
publicStringget(Stringurl,Stringcharset)throwsSocketTimeoutException{
OkHttpClientclient=buildOkHttpClient();
Requestrequest=createRequestBuilder(url).build();
try{
Responseresponse=client.newCall(request).execute();
if(response.isSuccessful()){
if(debug){
mpHeaders(response);
}
if(charset!=null&&!charset.equals("")){
returnnewString(response.body().bytes(),charset);
}
returnresponse.body().string();
}
}catch(SocketTimeoutExceptione){
throwe;
}catch(IOExceptione){
e.printStackTrace();
}
returnnull;
}
publicStringtryGet(Stringurl,inttryTimes){
Stringhtml=null;
booleandone=false;
intcount=0;
while(!done&&count<tryTimes){
try{
html=get(url);
done=true;
}catch(SocketTimeoutExceptione){
System.out.println("獲取鏈接["+url+"]內容超時,正在嘗試第"+(++count)+"次獲取......");
}
}
returnhtml;
}
publicStringpost(Stringurl,Map<String,String>postData,Stringcharset){
FormBody.BuilderformBodyBuilder=newFormBody.Builder();
for(Map.Entry<String,String>entry:postData.entrySet()){
formBodyBuilder.add(entry.getKey(),entry.getValue());
}
RequestBodyrequestBody=formBodyBuilder.build();
returnpost(url,requestBody,charset);
}
publicStringpost(Stringurl,MediaTypecontentType,Stringcontent,Stringcharset){
returnpost(url,FormBody.create(contentType,content),charset);
}
publicStringpost(Stringurl,RequestBodyrequestBody,Stringcharset){
OkHttpClientclient=buildOkHttpClient();
Request.BuilderrequestBuilder=createRequestBuilder(url);
Requestrequest=requestBuilder.post(requestBody).build();
try{
Responseresponse=client.newCall(request).execute();
if(response.isSuccessful()){
if(charset!=null&&!charset.equals("")){
returnnewString(response.body().bytes(),charset);
}
returnresponse.body().string();
}
}catch(IOExceptione){
e.printStackTrace();
}
returnnull;
}
(){
Builderbuilder=newOkHttpClient.Builder();
if(enableCookie){
builder.cookieJar(newCookieJar(){
@Override
publicList<Cookie>loadForRequest(HttpUrlurl){
List<Cookie>cookies=cookieContainer.get(url.host());
returncookies!=null?cookies:newArrayList<Cookie>();
}
@Override
publicvoidsaveFromResponse(HttpUrlurl,List<Cookie>cookies){
if(debug){
mpCookies(cookies);
}
cookieContainer.put(url.host(),cookies);
}
});
}
returnbuilder.build();
}
privateRequest.BuildercreateRequestBuilder(Stringurl){
Request.Builderbuilder=newRequest.Builder().url(url);
builder.addHeader("User-Agent",UserAgent);
returnbuilder;
}
privatevoidmpHeaders(Responseresponse){
System.out.println("----------Headers----------------------------------------------------------");
Headersheaders=response.headers();
for(Stringname:headers.names()){
System.out.println(name);
}
System.out.println("---------------------------------------------------------------------------");
}
privatevoidmpCookies(List<Cookie>cookies){
System.out.println("-------cookies-------------------------------------------------------------------");
for(Cookiecookie:cookies){
System.out.println(cookie);
}
System.out.println("---------------------------------------------------------------------------------");
}
}
❽ okhttp3 .responsebody.string 內存溢出
點開responsebody里的內存清理就好。
只要是使用時間長了都會有這種內存滿了的情況,我們只要及時清理就能解決。
OkHttp是一個相對成熟的解決方案,據說Android4.4的源碼中可以看到HttpURLConnection已經替換成OkHttp實現了,我們更有理由相信OkHttp的強大。