一、場景介紹
應用通過HTTP發起一個數據請求,支持常見的GET、POST、OPTIONS、HEAD、PUT、DELETE、TRACE、CONNECT方法。
二、 接口說明
HTTP數據請求功能主要由http模塊提供。
使用該功能需要申請ohos.permission.INTERNET權限。
涉及的接口如下表,具體的接口說明請參考API文檔。
接口名 | 功能描述 |
---|---|
createHttp() | 創建一個http請求。 |
request() | 根據URL地址,發起HTTP網絡請求。 |
destroy() | 中斷請求任務。 |
on(type: 'headersReceive') | 訂閱HTTP Response Header 事件。 |
off(type: 'headersReceive') | 取消訂閱HTTP Response Header 事件。 |
once('headersReceive')8+ | 訂閱HTTP Response Header 事件,但是只觸發一次。 |
熟悉[鴻蒙]文檔
鴻蒙OS開發 | 更多內容↓點擊 | HarmonyOS與OpenHarmony技術 |
---|---|---|
鴻蒙技術文檔 | 《鴻蒙NEXT星河版開發學習文檔》 |
三、request接口開發步驟
1.從@ohos.net.http.d.ts中導入http命名空間。
2.調用createHttp()方法,創建一個HttpRequest對象。
3.調用該對象的on()方法,訂閱http響應頭事件,此接口會比request請求先返回。可以根據業務需要訂閱此消息。
4.調用該對象的request()方法,傳入http請求的url地址和可選參數,發起網絡請求。
5.按照實際業務需要,解析返回結果。
6.調用該對象的off()方法,取消訂閱http響應頭事件。
7.當該請求使用完畢時,調用destroy()方法主動銷毀。
// 引入包名
import http from '@ohos.net.http';
// 每一個httpRequest對應一個HTTP請求任務,不可復用
let httpRequest = http.createHttp();
// 用于訂閱HTTP響應頭,此接口會比request請求先返回。可以根據業務需要訂閱此消息
// 從API 8開始,使用on('headersReceive', Callback)替代on('headerReceive', AsyncCallback)。 8+
httpRequest.on('headersReceive', (header) = > {
console.info('header: ' + JSON.stringify(header));
});
httpRequest.request(
// 填寫HTTP請求的URL地址,可以帶參數也可以不帶參數。URL地址需要開發者自定義。請求的參數可以在extraData中指定
"EXAMPLE_URL",
{
method: http.RequestMethod.POST, // 可選,默認為http.RequestMethod.GET
// 開發者根據自身業務需要添加header字段
header: {
'Content-Type': 'application/json'
},
// 當使用POST請求時此字段用于傳遞內容
extraData: {
"data": "data to send",
},
expectDataType: http.HttpDataType.STRING, // 可選,指定返回數據的類型
usingCache: true, // 可選,默認為true
priority: 1, // 可選,默認為1
connectTimeout: 60000, // 可選,默認為60000ms
readTimeout: 60000, // 可選,默認為60000ms
usingProtocol: http.HttpProtocol.HTTP1_1, // 可選,協議類型默認值由系統自動指定
}, (err, data) = > {
if (!err) {
// data.result為HTTP響應內容,可根據業務需要進行解析
console.info('Result:' + JSON.stringify(data.result));
console.info('code:' + JSON.stringify(data.responseCode));
// data.header為HTTP響應頭,可根據業務需要進行解析
console.info('header:' + JSON.stringify(data.header));
console.info('cookies:' + JSON.stringify(data.cookies)); // 8+
} else {
console.info('error:' + JSON.stringify(err));
// 取消訂閱HTTP響應頭事件
httpRequest.off('headersReceive');
// 當該請求使用完畢時,調用destroy方法主動銷毀
httpRequest.destroy();
}
}
);
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
HTTP
+關注
關注
0文章
504瀏覽量
31194 -
鴻蒙系統
+關注
關注
183文章
2634瀏覽量
66307 -
HarmonyOS
+關注
關注
79文章
1973瀏覽量
30143 -
OpenHarmony
+關注
關注
25文章
3713瀏覽量
16255 -
鴻蒙OS
+關注
關注
0文章
188瀏覽量
4383
發布評論請先 登錄
相關推薦
鴻蒙Flutter實戰:07混合開發
# 鴻蒙Flutter實戰:混合開發
鴻蒙Flutter混合開發主要有兩種形式。
## 1.基于har
將flutter module
發表于 10-23 16:00
鴻蒙OS崛起,鴻蒙應用開發工程師成市場新寵
應用的形態也在發生著翻天覆地的變化。作為全球領先的移動操作系統和智能終端制造商,華為公司自主研發的鴻蒙OS應運而生,致力于構建一個統一的分布式操作系統,為各行各業的應用開發帶來全新的可能性。
一、
發表于 04-29 17:32
鴻蒙OS開發實例:【HarmonyHttpClient】網絡框架
鴻蒙上使用的Http網絡框架,里面包含純Java實現的HttpNet,類似okhttp使用,支持同步和異步兩種請求方式;還有鴻蒙版retro
鴻蒙OS開發實例:【窺探網絡請求】
HarmonyOS 平臺中使用網絡請求,需要引入 "@ohos.net.http", 并且需要在 module.json5 文件中申請網絡權限, 即 “ohos.permission.
鴻蒙OS開發實戰:【打造自己的搜索入口】
包含,輸入框文字輸入,熱門詞展示,熱門帖子展示。全篇主要使用到的控件是TextInput, Flex, Swiper。為了貼近實戰,文字輸入過程中,也增加了聯想詞功能。整個示例將在模擬狀態下完成,不做任何網絡請求。
鴻蒙原生應用開發-網絡管理HTTP數據請求
一、場景介紹
應用通過HTTP發起一個數據請求,支持常見的GET、POST、OPTIONS、HEAD、PUT、DELETE、TRACE、CONNECT方法。
二、接口說明
HTTP
發表于 03-29 17:51
鴻蒙OS開發實例:【工具類封裝-http請求】
;@ohos.promptAction';**
**封裝HTTP接口請求類,提供格式化的響應信息輸出功能。
使用 DevEco Studio 3.1.1 Release 及以上版本,API 版本為 api 9 及以上
鴻蒙開發實戰:網絡請求庫【axios】
[Axios]?,是一個基于 promise 的網絡請求庫,可以運行 node.js 和瀏覽器中。本庫基于[Axios]原庫v1.3.4版本進行適配,使其可以運行在 OpenHarmony,并沿用其現有用法和特性。
鴻蒙實戰項目開發:【短信服務】
數據管理
電話服務
分布式應用開發
通知與窗口管理
多媒體技術
安全技能
任務管理
WebGL
國際化開發
應用測試
DFX面向未來設計
發表于 03-03 21:29
鴻蒙這么大聲勢,為何遲遲看不見崗位?最新數據來了
基礎》
ArkTS語言
安裝DevEco Studio
運用你的第一個ArkTS應用
ArkUI聲明式UI開發
.……
《鴻蒙開發進階》
Stage模型入門
網絡
發表于 02-29 20:53
2024款鴻蒙OS 最新HarmonyOS Next_HarmonyOS4.0系列教程分享
鴻蒙的出現,標志著中國科技的崛起。HarmonyOS就是我們說的華為鴻蒙系統,截止到2023年8月4日已有超過7億臺設備搭載了鴻蒙OS系統。據多家媒體報道,2024年國內有21所985
發表于 02-28 10:29
1月18號“純鴻蒙”千帆啟航,程序員預備!
……
《鴻蒙開發進階》http://qr61.cn/oWQPaX/qU3VHZO
1.Stage模型入門
2.網絡管理
3.
發表于 01-16 22:13
評論