當前位置:首頁 » 安卓系統 » android網路請求框架

android網路請求框架

發布時間: 2022-02-23 12:23:14

A. android 中有沒有好的tcp長連接框架

可以試試開源的框架:rxnetty
使用rxnetty只需要簡單的幾句話就能解決netty tcp長連接的實現過程,由於沒有handler所以使用一個方法再其他程序中使用能夠更加的方便;還有就是在使用可以通過使Lambda 表達式來簡化代碼,使代碼的可讀性能夠增加,還有就是在使用長鏈接的時候推薦使用rxAndroid,使用這個方法最主要的好處就是子線程可以很容易的將數據發送到主線程來更新界面

B. 請問android中一些第三方網路請求框架的回調函數都是運行在主線程還是子線程注意,是回調函數所

主線程吧 我記得像是XUitls 的連網回調函數。在onsuccess 和 onfailure 方法裡面,可以直接關閉彈出的聯網進度條 既然可以修改控制項,應該就是在主線程了吧

C. android底層網路框架是怎麼實現的

一個好用的網路底層框架可以很大的程度上方便自己的項目,我們下面要做的就是一個趁手的網路框架。
做一個網路框架我們首先要確定這個網路框架除了能夠從網路上獲取數據還需要哪些功能:
首先拋棄AsyncTask,自定義一套網路底層的封裝框架。
設計一套適合自己App的緩存策略
設計一套假數據返回的機制,在網路請求API沒有返回的時候,可以假裝獲取到了網路返回的數據。
封裝用戶cookie的邏輯。
其他的還好,可能有人對於第一步的那個拋棄AsyncTask有些疑問,就是為什麼要拋棄啊,這個類這個好用,內部封裝了那麼多的方法。但是我們不能只看到這個的優點,這個類有個致命的缺點:不能靈活的控制內部的線程池。
我們都知道的是,線程池裡面的每個線程都是API的調用請求,而AsyncTask中有沒有暴漏出取消這些請求的方法,這個時候,如果我們從A界面調到B界面,那麼在A界面調用的API請求,如果還沒有返回,並不會被取消,對於一個頻繁調用API請求的APP應用應用來說,一個界面調用的API可能超過十個,在網路不好的情況下,如果這個時候跳轉到了其他界面,這個時候其他界面也會調用API,這個時候造成的情況就是這個界面的請求並不會顯示數據,因為首頁的請求還在排隊,要等首頁的請求完成之後你才可以調用,這個就是所謂的AsyncTask堵塞。
我剛工作的時候遇到一個情況就是,根據公司的情況寫了一個統計用戶交互數據的SDK,開始的使用時候就是這個AsyncTask類,結構我發現在APP中某一個界面的吊起特別的慢,數據載入也非常的慢,發現的原因是我寫的這個SDK中的API請求調用超時,並且在超時的時候重復調用三次這個API。

網路請求的格式
網路請求兩個方法POST和GET,我們一般把GET方法為請求數據,POST為修改數據。請求的方法格式也是相對有講究的。

Request
所有的MobileApi都可以寫作:http://www.xxx.com/aaaa.api的形式。
GET:對於GET方法我們可以將請求API寫作http://www.xxx.com/aaaa.api K1=va1&K2=va2,形式,也就是說,把key-value這樣的鍵值對存放在URL上,這樣做的話會方便我們後面對數據進行緩存,另外要精良是GET的參數都是String,int這樣的類型,方便緩存,解析。
POST:我們都知道看不見POST的請求數據,一般key-value這樣的鍵值對存放在Form表單中,最後進行提交請求。POST經常會提交大量數據,所以有些鍵值對要定義成集合或復雜的自定義實例,這個時候我們就需要把這樣的值轉換為JSON字元串進行提交,有APP傳遞到API後,在將JSON字元串轉換為對於的實體。
Response
伺服器現在用的最多的是使用JSON作為api返回的結果,這里也是使用JSON。
一般情況下返回的json數據中要有以下數據:
首先一個是否調用api成功的參數,
另外一個錯誤類型的參數(這個參數可以是Int格式的參數,成功為0)
錯誤具體信息的參數,成功為「」
具體API返回的結果,失敗為「」
所以我們定義一個Response實體類,作為JSON實體的最外層。
如果成功返回了數據,數據會存放在result字元按中,映射為Response實體的result屬性。

如果上面返回的result是一種實體的集合,那麼就要把result解析為相應的實體集合。
我們在前面看到我們把AsyncTask拋棄重新寫一個擴展性強的,可以隨時取消API請求網路底層,那麼我們的這個網路底層的線程池使用的是什麼:使用原生的ThreadPoolExecutor + Runnable + Handler
首先我們要把App所調用的所有的API介面放到一個類或者xml文件中去,我們這里放在xml文件裡面去,當然要寫出讀取xml的類和函數:
其中key和url的值符合key-value鍵值,expires代表數據緩存的時間單位為毫秒,netType代表請求方式(POST和GET) ,mockClass代表的是返回假數據的類。
RemoteService和RequestCallback和RequestParameter
這三個類表示的是請求的服務,請求返回,請求參數,三個給APP調用的類。
其他的兩個類在方法中調用:

context:表示上下文
key:即xml文件中的key
RequestParameter:請求攜帶的參數
callback:請求回調
forceUpdate:是否強制更新數據,忽略緩存
RequestMannager類是一個集合類,用於取消請求的。每次發起請求時,都會把為此創建的Request添加到RequestManager中,即RequestManager中保存了全部的request。
他是對ThreadPoolExecutor和ArrayBlockingQueue的簡單封裝,是一個線程池,每發起一次請求,這個線程池就會分配一個新的線程來執行該請求。

HttpRequest類,發起HTTP請求的地方,他事先了Runable,從而讓DefaultThreadPool可以分配新的線程,所以所有的請求邏輯都在Runnable介面方法里:
在這個類中對於get請求介面,他會把傳遞來的數據,處理為相應的格式:http://www.xxx.com/aaaa.api K1=va1&K2=va2。對於Post格式的請求介面,他會把傳遞過來的數據轉換為BasicNameValuePair的形式,並放在表單中提交。

需要注意的是,因為我們把每個HttpRequest都放在了子線程中執行,所以RequestCallback的回調不能直接操作UI線程的控制項,所以這個時候Handler就可以用到了。使用這個就可以保證RequestCallback的回調在UI線程上,不會報錯。

D. android 怎樣將線程池封裝到自己的網路請求底層

對非同步請求封裝 ,可用作基本項目框架來使用
1)封裝HttpClient
2)由於用到線程池,可以進行多任務網路請求操作
3)沒有網路的時候進行網路狀態檢查
4)對請求的數據根據URL進行緩存到本地sqlite資料庫
5)本demo可以直接運行 本來想測試protobuf進行數據處理的 要放在github上就改成json了
只能提供大概輪廓,代碼還是需要你去寫,因為你的項目只能根據你想法來寫

E. android網路框架怎麼調用

我們在做項目中一定少不了網路請求,現在很多公司的網路請求這塊好多都是使用一些比較好的開源框架,我項目中使用的是volley,現在講講一些volley基本的使用,如果想要詳細的了解就要去看它的源碼了,現在貼代碼講一些它的使用了,
首先用一個類去封裝下它的基本配置信息,以後需要變動的話,就直接在這里做修改,Android最好能把每個功能都獨立出來,這樣做修改的話 不會導致出現其他的bug,特別在有新員工進入到項目組中,分配任務溝通起來也省事,
ProtocolManager.java 它是一個單例

關鍵代碼

[java] view plain print?
private ProtocolManager(Context context){
initLoadBitmapConfig(context);
mQueue = Volley.newRequestQueue(context);
}

我們在調介面的時候 只需要這樣:

[java] view plain print?
Map<String,String> param = new HashMap<String, String>();
param.put("checksum", 0+"");

F. Android中訪問網路的框架有哪些

回答
Android中訪問網路的框架有哪些?
請列舉四種訪問網路的框架(有什麼特點並介紹)簡短一些就好。
展開
Android開發 Android應用 Android 開發 App

G. android幾種網路框架的比較

現在 OkHttp 已經一統 android 的江山,但是基於 OkHttp 再次封裝的 框架層出不窮

推薦直接使用 OkHttp 的增強版本 OkHttps , 15秒便可上手,超級好用,這是官方中文文檔地址:okhttps.ejlchina.com

H. Android面試網路框架封裝我應該說什麼

rxjava2+retrofit+mvp

I. android app開發中常用到哪些開源框架

在前面的課程中,隨著對Android體系的了解,已經可以進行正常的Android應用開發了。在Android開發中,同其他工程開發一樣,也經常使用一些提高效率的框架,本文我們做一個對比。這些框架,既包括:網路請求框架、也包括圖片載入庫框架、還包括資料庫操作等一些框架,總之,了解和熟悉這些框架,會對自己的開發效率有很大的提升和幫助。

網路請求框架

1、okHttp

在前文的學習中,我們已經了解過okHttp,是一個常用的網路載入庫。

2、Retrofit

介紹

Retrofit是一個很不錯的網路請求庫,該庫是square開源的另外一個庫,之前的okhttp也是該公司開源的。

Retrofit是基於OkHttp封裝的RESTful網路請求框架,使用註解的方式配置請求。優點是速度快,使用註解,callback函數返回結果自動包裝成Java對象。官方自己的介紹說:

A type-safe REST client for Android and Java

該網路框架在github上的地址如下:https://square.github.io/retrofit/

要求

Retrofit支持的http方式方式包括 GET/POST/PUT/DELETE/HEAD/PATCH,Retrofit要求Java的版本是1.8+,Android應用的API版本應該在21+。

依賴

使用Retrofit庫,和其他庫一樣,首先需要設置依賴,依然是在build.gradle文件中設置依賴:

//添加retrofit庫依賴

implementation 『com.squareup.retrofit2:retrofit:2.1.0』

//添加gson轉換器

implementation 『com.squareup.retrofit2:converter-gson:2.1.0』

使用

通過一個例子,我們可以來演示該框架的使用步驟:

1、定義請求介面,即程序中都需要什麼請求操作
public interface HttpServices {

/**

  • 獲取頭條新聞

  • @param type 新聞類型

  • @param key apiKey

  • @return

  • */

    @GET(「toutiao/index」)

    Call getNewsList(@Query(「type」) String type, @Query(「key」) String key);

    }

    2、實例化Retrofit對象,使用的Builder的模式創建,如下代碼所示:
    Retrofit retrofit = new Retrofit.Builder()

    .baseUrl(Constants.BASE_API)

    .addConverterFactory(GsonConverterFactory.create())

    .build();

    注意,這里設置結構體轉換器,是可以直接把網路請求回來的數據轉換為Java結構體,這里設置的Gson解析器,因此要引入相應的轉換器支持庫。

    3、得到介面對象,自己創建的全局的介面對象,並調用相應的介面,得到一個類似於請求Call對象。如下所示:
    HttpServices httpServices = retrofit.create(HttpServices.class);

    Call newsListCall = httpServices.getNewsList(「top」, Constants.API_KEY);

    4、加入到請求隊列中,並設置回調方法:
    newsListCall.enqueue(new Callback() {

    @Override

    public void onResponse(Call call, Response response) {

    //網路請求成功的回調方法

    List list = Arrays.asList(response.body().result.data);

    Log.i(「TAG」, 「請求成功:」 + String.valueOf(list.size()));

    NewListAdapter adapter = new NewListAdapter(RetrofitActivity.this);

    adapter.setmData(list);

    mRecyclerView.setAdapter(adapter);

    }

    @Override

    public void onFailure(Call call, Throwable throwable) {

    //網路請求失敗的回調方法

    Log.i(「TAG」, 「請求失敗:」 + throwable.getMessage());

    }

    });

    其他界面操作和之前的Android中的內容一致。

    3、RxJava

    簡單來說,用來處理事件和非同步任務,在很多語言上都有實現,RxJava是Rx在Java上的實現。

    原理

    RxJava最基本的原理是基於觀察者模式來實現的。通過Obserable和Observer的機制,實現所謂響應式的編程體驗。

    特點

    RxJava在編程中的實現就是一種鏈式調用,做了哪些操作,誰在前誰在後非常直觀,邏輯清晰,代碼維護起來非常輕松。

    RxJava也是一個在github上的庫,githubhttp://www.xingkongmj.com/news/id/62.html地址如下:https://github.com/ReactiveX/RxJava

    基於此,還有一個RxAndroid,github地址如下:https://github.com/ReactiveX/RxAndroid

    RxJava和RxAndroid的關系

    RxAndroid是RxJava的一個針對Android平台的擴展,主要用於 Android 開發。

    基本概念

    RxJava 有四個基本概念:

    Observable:可觀察者,即被觀察者Observer:觀察者subscribe:訂閱事件
    這四個概念之間的邏輯關系是:Observable和Observer通過subscribe方法實現訂閱關系,從而Observable可以在需要的時候發出事件來通知Observer。

    事件

    RxJava 的事件回調方法主要包含以下幾個:

    onNext:普通的事件onCompletedhttp://dachang.net/432717.html:事件隊列完結。RxJava 不僅把每個事件單獨處理,還會把它們看做一個隊列。RxJava 規定,當不會再有新的 onNext 發出時,需要觸發 onCompleted 方法作為標志。:事件隊列異常。在事件處理過程中出異常時, 會被觸發,同時隊列自動終止,不再允許再有事件發出。在一個正確運行的事件序列中, onCompleted和 有且只有一個,並且是事件序列中的最後一個。需要注意的是,onCompleted() 和 () 二者也是互斥的,即在隊列中調用了其中一個,就不應該再調用另一個。
    資料庫操作框架

    在開發時,本地資料庫可以起到緩存數據和存儲業務數據的作用,隨著技術的成熟,不斷推出了有很多關於資料庫的操作框架。比較常見的資料庫操作框架有諸如:GreenDao,OrmLite 和 ActiveAndroid,DBFlow等。

    GreenDAO

    GreenDAO是一個開源的 Android ORM(「對象/關系映射」),通過 ORM(稱為「對象/關系映射」),在我們資料庫開發過程中節省了開發時間!

    GreenDao的官方文檔地址如下:http://www.xingkongmj.com/news/id/63.html

    GreenDao的作用

    通過 GreenDao,我們可以更快速的操作資料庫,我們可以使用簡單的面相對象的API來存儲,更新,刪除和查詢 Java 對象。這款資料庫操作框架的特點是:

    高性能,在官方的統計數據中,GreenDao在GreenDao,OrmLite 和 ActiveAndroid三個框架中,讀、寫、更新操作效率均表現第一。易於使用的強大 API,涵蓋關系和連接。內存消耗較小。安全:greenDAO 支持 SQLCipherhttp://www.xingkongmj.com/news/id/64.html,以確保用戶的數據安全;
    核心概念

    GreenDao 的核心類有三個:分別是:

    DaoMaster:保存資料庫對象(SQLiteDatabase)並管理特定模式的 DAO 類(而不是對象)。它有靜態方法來創建表或刪除它們。它的內部類 OpenHelper 和DevOpenHelper 是 SQLiteOpenHelper 實現,它們在 SQLite 資料庫中創建模式。DaoSession:管理特定模式的所有可用 DAO 對象,您可以使用其中一個getter方法獲取該對象。DaoSession 還提供了一些通用的持久性方法,如實體的插入,載入,更新,刷新和刪除。XXXDao:數據訪問對象(DAO)持久存在並查詢實體。對於每個實體,greenDAO 生成DAO。它具有比 DaoSession 更多的持久性方法。Entities:可持久化對象。通常, 實體對象代表一個資料庫行使用標准 Java 屬性(如一個POJO 或 JavaBean )。
    使用

    按照官方的文檔和github上的說明可以實現green的使用。

    首先進行的是依賴,對於greenDao,有兩個地方需要設置,分別是項目根目錄中的 build.gradle,還有mole中的build.gradle。
    classpath 『org.greenrobot:green-gradle-plugin:3.3.0』 // add plugin

    在項目根目錄中的build.gradle目錄中寫這句話的意思是添加greenDao的插件。

    在項目mole中的build.gradle中也需要進行配置,有兩個地方需要設置,如下圖所示:

    apply plugin: 『org.greenrobot.greenhttp://www.xingkongmj.com/news/id/66.html』 //開頭加入該代碼

    dependences{

    implementation 『org.greenrobot:green:3.2.0』

    }

    然後就可以使用了。

    bean實體

    可以在項目中創建自己業務需要的實體類,並通過註解來設置是實體類,欄位約束等內容。然後點擊Android Studio中的Make mole,即可自動生成XXXDao代碼,以此來方便開發者的操作。生成的XXXDao類,不可修改和編輯,是自動生成的。

    ORMLite

    ORMLite框架是另外一款Android開發中可以使用的資料庫操作框架。該框架的文檔地址如下:https://ormlite.com/sqlite_java_android_orm.shtml

    該框架的文檔准備的不是特別友好,此處不再贅述。

    總結,所有的框架原理幾乎都相差不大,只是操作有所差異。

    視圖注入框架

    在Android項目開發過程中,有太多的頁面需要布局完成,同時在代碼中需要些大量的findviewbyid的操作,來實現控制項的解析。於是就有人想能否輕松一些,解放雙手節省時間,干一些其他有意義的事情,於是ButterKnife就來了。

    ButterKnife是一個專注於Android系統的View注入框架,可以減少大量的findViewById以及setOnClickListener代碼,可視化一鍵生成。

    該項目在github上的地址如下:http://www.xingkongmj.com/news/id/65.html

    這個框架的優勢也非常明顯:

    強大的View綁定和Click事件處理功能,簡化代碼,提升開發效率方便的處理Adapter里的ViewHolder綁定問題運行時不會影響APP效率,使用配置方便代碼清晰,可讀性強
    使用

    首先是設置依賴,在build.gradlehttp://dachang.net/432714.html中進行依賴設置:

    implementation 『com.jakewharton:butterknife:10.2.1』

    annotationProcessor 『com.jakewharton:butterknife-compiler:10.2.1』

    需要注意,該框架要求Java環境1.8版本以上,SDK版本在26以上,因此在使用到的mole中的build.graldle文件中,還必須添加如下代碼配置:

    apply plugin: 『com.jakewharton.butterknife』

    android{

    //…

    compileOptions {

    sourceCompatibility JavaVersion.VERSION_1_8

    targetCompatibility JavaVersion.VERSION_1_8

    }

    //…

    }

    另外,還必須在項目根目錄中的build.gradle文件中,添加該框架的插件,如下圖所示:

    dependences{

    classpath 『com.jakewharton:butterknife-gradle-plugin:10.2.1』

    }

    然後即可在代碼中進行使用了。

    在使用該框架的頁面進行綁定諸如,如下所示代碼:

    ButterKnife.bind( this) ;

    主要的功能

    @BindView():控制項id 註解,解放雙手,不用再每個控制項都寫一遍findviewById@BindViews():多個控制項id 的註解,括弧內使用花括弧包括多個id即可,中間用,分割開在Fragment中使用,綁定Fragment。@BindString():綁定字元串@BindArray:綁定數組@BindBitmap:綁定bitmap資源@OnClick、@OnLongClick:綁定點擊事件和長按事件…還有很多
    插件安裝

    如果是頁面很復雜,一個一個寫BindView也很費勁,在Android Studio中,可以安裝一個ButterKnife的插件,安裝該插件後,可以在Studio中直接將對應的布局中的所有控制項均給自動生成。

    注意,在進行自動生成時,滑鼠要放在布局文件上。

    注意事項

    ButterKnife框架在使用時,要求的版本比較高,包括Java的版本也有限制。因此,如果計劃在項目中使用,要提前做好預備工作,以防止對已有項目和業務帶來不必要的麻煩,反而影響工作進度。

J. android怎麼用okhttp封裝網路框架

封裝只是為了能更加簡單,僅此而已~
功能
UI 線程切換
可選擇的Callback(任意選擇UI線程或者子線程)
參數規范化,GET與POST都一樣的傳參方式
上傳/下載進度回調
可以簡單的設置Head部分
可以每次請求時自動加上需要的參數
String/JSON/byte/File… 都能一樣簡單
用法
由於輔助代碼較多,在這里就不一一貼出來了,在這里僅僅演示如何使用。
非同步GET
Http.getAsync("http://wthrcdn.etouch.cn/weather_mini", new UiCallback<String>() {
@Override
public void onFailure(Request request, Response response, Exception e) {
log("getAsync:onFailed");
}

@Override
public void onSuccess(String response, int code) {
log("getAsync:onSuccess:" + response);
}
}, new StrParam("citykey", 101010100)
);123456789101112

由於是 get 請求,在這里參數中的 citykey 會被自動解析到 url 中。
http://wthrcdn.etouch.cn/weather_mini?citykey=1010101001

同步GET
final String url = "http://wthrcdn.etouch.cn/weather_mini?citykey=101010100";
String str = Http.getSync(String.class, url);
log("getSync1:" + str);

str = Http.getSync(url, new ThreadCallback<String>() {
@Override
public void onFailure(Request request, Response response, Exception e) {
log("getSync2:onFailed");
}

@Override
public void onSuccess(String response, int code) {
log("getSync2:onSuccess:" + response);
}
});
log("getSync2:" + str);12345678910111213141516

同步方式支持兩種情況,一種有Callback,一種是沒有。
當然就算加上了Callback也並不是非同步,此時方法會等到執行完成後才會繼續往下走。之所以這么干,是為了方便在callback中直接處理ui的事兒。
在這里有必要說明一下,返回類型需要進行指定,如果沒有Callback哪么需要你傳入返回類型class。
當然如果你傳入了callback,哪么此時class就由callback
Account account = Http.getSync(Account.class, url);
User user = Http.getSync(User.class, url);
String str = Http.getSync(String.class, url, new StrParam("citykey", 101010100));123

Callback 的情況也如上所示。
非同步與同步的區別在於方法名稱:
Http.getSync()
Http.getAsync()
Http.postSync()
Http.postAsync()
Http.uploadSync()
Http.uploadAsync()
Http.downloadSync()
Http.downloadAsync()
默認情況下,upload與download具有callProgress 回調進度功能。
POST
String value1 = "xxx";
String value2 = "xxx";
String url = "http://www..com";

Http.postAsync(url, new HttpCallback<String>() {
@Override
public void onFailure(Request request, Response response, Exception e) {
e.printStackTrace();
}

@Override
public void onSuccess(String response, int code) {
log(response);
}
},
new StrParam("value1", value1),
new StrParam("value2", value2));1234567891011121314151617

post 的請求方法與get基本如出一轍。
Upload
File file = getAssetsFile();
Http.uploadAsync("http://img.hoop8.com/upload.php", "uploadimg", file, new UiCallback<String>() {
@Override
public void onProgress(long current, long count) {
super.onProgress(current, count);
log("uploadAsync onProgress:" + current + "/" + count);
mUpload.setProgress((int) ((current * 100.00 / count)));
}

@Override
public void onFailure(Request request, Response response, Exception e) {
e.printStackTrace();
log("uploadAsync onFailed");
}

@Override
public void onSuccess(String response, int code) {
log("uploadAsync onSuccess:" + response);
}
});

上傳部分也很簡單,如果需要帶有參數哪么和Post的使用方式一樣。當然此時傳入參數就不是 StrParam 而是 IOParam.
上傳的時候你可以僅僅傳遞文件+文件對應的name;或者 傳遞 IOParam; 也可以 StrParam+IOParam的方式;當然終極一點你可以傳遞:Param 類型。

熱點內容
實現秘聞存儲的方法 發布:2025-02-08 10:23:33 瀏覽:168
怎麼在微信發文件夾 發布:2025-02-08 10:09:45 瀏覽:795
cryengine源碼 發布:2025-02-08 09:50:58 瀏覽:394
aardio可以反編譯嗎 發布:2025-02-08 09:50:53 瀏覽:484
公司營業執照密碼是什麼 發布:2025-02-08 09:47:56 瀏覽:855
體驗腳本 發布:2025-02-08 09:46:15 瀏覽:691
醫學生需要什麼配置的筆記本 發布:2025-02-08 09:45:34 瀏覽:772
騷擾電話資料庫 發布:2025-02-08 09:45:34 瀏覽:180
u盤文件加密器 發布:2025-02-08 09:40:35 瀏覽:770
plc數據存儲app 發布:2025-02-08 09:37:17 瀏覽:709