Flutter開發(fā)(10)- 網(wǎng)絡(luò)請(qǐng)求

????項(xiàng)目中展示的大部分?jǐn)?shù)據(jù)都是來(lái)自服務(wù)器砾赔,我們需要向服務(wù)器請(qǐng)求數(shù)據(jù),并且對(duì)他們進(jìn)行解析展示。

????向服務(wù)器發(fā)出請(qǐng)求就需要用到網(wǎng)絡(luò)請(qǐng)求相關(guān)的知識(shí)佳恬。

一. 網(wǎng)絡(luò)請(qǐng)求的方式

在Flutter中常見的網(wǎng)絡(luò)請(qǐng)求方式有三種:HttpClient、http庫(kù)于游、dio庫(kù)殿怜;

1.1. HttpClient

HttpClient是dart自帶的請(qǐng)求類,在io包中曙砂,實(shí)現(xiàn)了基本的網(wǎng)絡(luò)請(qǐng)求相關(guān)的操作头谜。

網(wǎng)絡(luò)調(diào)用通常遵循如下步驟:

????創(chuàng)建 client.

????構(gòu)造 Uri.

????發(fā)起請(qǐng)求, 等待請(qǐng)求,同時(shí)您也可以配置請(qǐng)求headers鸠澈、 body柱告。

????關(guān)閉請(qǐng)求, 等待響應(yīng).

????解碼響應(yīng)的內(nèi)容.

網(wǎng)絡(luò)請(qǐng)求實(shí)例:

void requestNetwork() async {

? // 1.創(chuàng)建HttpClient對(duì)象

? final httpClient = HttpClient();

? // 2.構(gòu)建請(qǐng)求的uri

? final uri = Uri.parse("http://123.207.32.32:8000/api/v1/recommend");

? // 3.構(gòu)建請(qǐng)求

? final request = await httpClient.getUrl(uri);

? // 4.發(fā)送請(qǐng)求,必須

? final response = await request.close();

? if (response.statusCode == HttpStatus.ok) {

? ? print(await response.transform(utf8.decoder).join());

? } else {

? ? print(response.statusCode);

? }

}

OK笑陈,其實(shí)HttpClient也可以發(fā)送post相關(guān)的請(qǐng)求际度,我們這里就不再演練。

HttpClient雖然可以發(fā)送正常的網(wǎng)絡(luò)請(qǐng)求涵妥,但是會(huì)暴露過(guò)多的細(xì)節(jié):

????比如需要主動(dòng)關(guān)閉request請(qǐng)求乖菱,拿到數(shù)據(jù)后也需要手動(dòng)的進(jìn)行字符串解碼

在開發(fā)中,我們一般很多直接面向HttpClient進(jìn)行網(wǎng)絡(luò)請(qǐng)求蓬网,而是使用一些庫(kù)來(lái)完成窒所。

1.2. http庫(kù)

http 是 Dart 官方提供的另一個(gè)網(wǎng)絡(luò)請(qǐng)求類,相比于 HttpClient帆锋,易用性提升了不少吵取。

但是,沒有默認(rèn)集成到Dart的SDK中锯厢,所以我們需要先在pubspec中依賴它:

? http:^0.12.0+2

導(dǎo)入并且使用即可

import'package:http/http.dart'as http;

void httpNetwork() async {

? // 1.創(chuàng)建Client

? final client = http.Client();

? // 2.構(gòu)建uri

? final url = Uri.parse("http://123.207.32.32:8000/api/v1/recommend");

? // 3.發(fā)送請(qǐng)求

? final response = await client.get(url);

? // 4.獲取結(jié)果

? if (response.statusCode == HttpStatus.ok) {

? ? print(response.body);

? } else {

? ? print(response.statusCode);

? }

}

1.3. dio三方庫(kù)

官方提供的HttpClient和http都可以正常的發(fā)送網(wǎng)絡(luò)請(qǐng)求皮官,但是對(duì)于現(xiàn)代的應(yīng)用程序開發(fā)來(lái)說(shuō),我們通常要求的東西會(huì)更多:比如攔截器实辑、取消請(qǐng)求捺氢、文件上傳/下載、超時(shí)設(shè)置等等剪撬;

這個(gè)時(shí)候摄乒,我們可以使用一個(gè)在Flutter中非常流行的三方庫(kù):dio;

官網(wǎng)有對(duì)dio進(jìn)行解釋:

????dio是一個(gè)強(qiáng)大的Dart Http請(qǐng)求庫(kù),支持Restful API缺狠、FormData问慎、攔截器、請(qǐng)求取消挤茄、Cookie管理如叼、文件上傳/下載、超時(shí)穷劈、自定義適配器等...

使用dio三方庫(kù)必然也需要先在pubspec中依賴它:

? dio:^3.0.1

代碼演練:

import'package:dio/dio.dart';

void dioNetwork() async {

? // 1.創(chuàng)建Dio請(qǐng)求對(duì)象

? final dio = Dio();

? // 2.發(fā)送網(wǎng)絡(luò)請(qǐng)求

? final response = await dio.get("http://123.207.32.32:8000/api/v1/recommend");

? // 3.打印請(qǐng)求結(jié)果

? if (response.statusCode == HttpStatus.ok) {

? ? print(response.data);

? } else {

? ? print("請(qǐng)求失斄 :${response.statusCode}");

? }

}

1.4. dio庫(kù)的封裝

http_config.dart

class HTTPConfig {

? staticconst baseURL = "https://httpbin.org";

? staticconst timeout = 5000;

}

http_request.dart

import'package:dio/dio.dart';

import'package:testflutter001/service/config.dart';

class HttpRequest {

? staticfinal BaseOptions options = BaseOptions(

? ? ? baseUrl: HTTPConfig.baseURL, connectTimeout: HTTPConfig.timeout);

? staticfinal Dio dio = Dio(options);

? static Future<T> request<T>(String url,

? ? ? {String method = 'get', Map<String, dynamic> params, Interceptor inter}) async {

? ? // 1.請(qǐng)求的單獨(dú)配置

? ? final options = Options(method: method);

? ? // 2.添加第一個(gè)攔截器

? ? Interceptor dInter = InterceptorsWrapper(

? ? ? onRequest: (RequestOptions options) {

? ? ? ? // 1.在進(jìn)行任何網(wǎng)絡(luò)請(qǐng)求的時(shí)候, 可以添加一個(gè)loading顯示

? ? ? ? // 2.很多頁(yè)面的訪問(wèn)必須要求攜帶Token,那么就可以在這里判斷是有Token

? ? ? ? // 3.對(duì)參數(shù)進(jìn)行一些處理,比如序列化處理等

? ? ? ? print("攔截了請(qǐng)求");

? ? ? ? return options;

? ? ? },

? ? ? onResponse: (Response response) {

? ? ? ? print("攔截了響應(yīng)");

? ? ? ? return response;

? ? ? },

? ? ? onError: (DioError error) {

? ? ? ? print("攔截了錯(cuò)誤");

? ? ? ? return error;

? ? ? }

? ? );

? ? List<Interceptor> inters = [dInter];

? ? if (inter != null) {

? ? ? inters.add(inter);

? ? }

? ? dio.interceptors.addAll(inters);

? ? // 3.發(fā)送網(wǎng)絡(luò)請(qǐng)求

? ? try {

? ? ? Response response = await dio.request<T>(url, queryParameters: params, options: options);

? ? ? return response.data;

? ? } on DioError catch(e) {

? ? ? return Future.error(e);

? ? }

? }

}

代碼使用:

HttpRequest.request("https://httpbin.org/get", params: {"name": "why", 'age': 18}).then((res) {

? print(res);

});

HttpRequest.request("https://httpbin.org/post",

? ? ? ? ? ? ? ? ? ? method: "post", params: {"name": "why", 'age': 18}).then((res) {

? print(res);

});

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市歇终,隨后出現(xiàn)的幾起案子社证,更是在濱河造成了極大的恐慌,老刑警劉巖评凝,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件追葡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡奕短,警方通過(guò)查閱死者的電腦和手機(jī)宜肉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)翎碑,“玉大人谬返,你說(shuō)我怎么就攤上這事∪砧荆” “怎么了遣铝?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)莉擒。 經(jīng)常有香客問(wèn)我酿炸,道長(zhǎng),這世上最難降的妖魔是什么啰劲? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任梁沧,我火速辦了婚禮,結(jié)果婚禮上蝇裤,老公的妹妹穿的比我還像新娘。我一直安慰自己频鉴,他們只是感情好栓辜,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著垛孔,像睡著了一般藕甩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上周荐,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天狭莱,我揣著相機(jī)與錄音僵娃,去河邊找鬼。 笑死腋妙,一個(gè)胖子當(dāng)著我的面吹牛默怨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播骤素,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼匙睹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了济竹?” 一聲冷哼從身側(cè)響起痕檬,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎送浊,沒想到半個(gè)月后梦谜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡袭景,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年改淑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片浴讯。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡朵夏,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出榆纽,到底是詐尸還是另有隱情仰猖,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布奈籽,位于F島的核電站饥侵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏衣屏。R本人自食惡果不足惜躏升,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望狼忱。 院中可真熱鬧膨疏,春花似錦、人聲如沸钻弄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)窘俺。三九已至饲帅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間灶泵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工髓棋, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留深纲,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓儒喊,卻偏偏與公主長(zhǎng)得像怀愧,于是被迫代替她去往敵國(guó)和親余赢。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容