鴻蒙中Axios數(shù)據(jù)請求的封裝和配置方法
適用于(HarmonyOS NEXT/5.0/API12+)
1.配置權(quán)限 應(yīng)用級權(quán)限和系統(tǒng)級權(quán)限

2.配置網(wǎng)絡(luò)請求的代碼
"requestPermissions": [
{ "name": "ohos.permission.INTERNET" }
],3.下載在Entry中 下載Axios
//終端中運(yùn)行
ohpm install @ohos/axios
4.封裝Http請求
實(shí)現(xiàn)思路:
//1.創(chuàng)建AXIOS的實(shí)例對象
//配置基地址,超時(shí)時(shí)間
//2.配置請求攔截器
//3.配置響應(yīng)攔截器
//4.封裝Htpp類
//5.創(chuàng)建并導(dǎo)出 http實(shí)例對象
//6.統(tǒng)一導(dǎo)出
import axios, { AxiosError, AxiosRequestConfig, AxiosResponse } from "@ohos/axios"
import { logger } from "./Logger"
const baseURL = 'https://api-harmony-teach.itheima.net'
//1.創(chuàng)建AXIOS的實(shí)例對象
//配置基地址,超時(shí)時(shí)間
//create 創(chuàng)建一個(gè)新的Axios對象 可以多個(gè)接口使用
export const instance =axios.create({
baseURL,
timeout:6000
})
//2.配置請求攔截器 (前端給后端的東西)
instance.interceptors.request.use((config:InternalAxiosRequestConfig)=>{
const user = auth.getUser()
if(user.token){
config.headers.Authorization = `Bearer ${ user.token}`
}
return config
},(err: AxiosError) => {
logger.error('Req Error', JSON.stringify(err))
return Promise.reject(err)
})
//3.配置響應(yīng)攔截器 后端給前端的東西
// instance.interceptors.response.use(()=>{成功} ,()=>{失敗})
//攔截器interceptors
//response通常指的是網(wǎng)絡(luò)請求的響應(yīng)。這是一個(gè)結(jié)構(gòu)體,用于封裝服務(wù)器返回的信息,
//AxiosResponse是Axios庫中的一個(gè)接口,用于表示HTTP響應(yīng)。以便開發(fā)者可以輕松地訪問響應(yīng)的各個(gè)部分。
instance.interceptors.response.use((res: AxiosResponse) => {
//成功
if (res.data.code === 10000) {
logger.debug('Req Success', JSON.stringify(res.data.data))
return res.data.data
}
//請求成功,回傳是錯誤的
logger.error('Req Error', JSON.stringify(res.data))
return Promise.reject(res.data)
}, (err: AxiosError) => {
//失敗返回的錯誤
logger.error('Req Error', JSON.stringify(err))
return Promise.reject(err)
})
//4.封裝Htpp類
// 提供request方法
class Http {
// Get 請求可以省略第二個(gè)泛型,因?yàn)閍xios默認(rèn)是any任何值可傳
//ResponseData 響應(yīng)數(shù)據(jù)類型 返回的數(shù)據(jù)(響應(yīng)回來的數(shù)據(jù))
//RequestData 請求數(shù)據(jù)類型 請求攜帶的參數(shù)
//Object 給個(gè)默認(rèn)值 有的是入?yún)?
//AxiosResponse是Axios庫中的一個(gè)接口,用于表示HTTP響應(yīng)。以便開發(fā)者可以輕松地訪問響應(yīng)的各個(gè)部分。
// request<T,D>
//T是自己的,D是請求得到
request<ResponseData, RequestData = Object>(config: AxiosRequestConfig<RequestData>) {
return instance<null, ResponseData, RequestData>(config)
}
}
//5.創(chuàng)建并導(dǎo)出 http實(shí)例對象
export const http = new Http()5.頁面中使用
import axios, { AxiosError, AxiosRequestConfig, AxiosResponse } from "@ohos/axios"
import { logger } from "./Logger"
const baseURL = 'https://api-harmony-teach.itheima.net'
//1.創(chuàng)建AXIOS的實(shí)例對象
//配置基地址,超時(shí)時(shí)間
//create 創(chuàng)建一個(gè)新的Axios對象 可以多個(gè)接口使用
export const instance =axios.create({
baseURL,
timeout:6000
})
//2.配置請求攔截器 (前端給后端的東西)
instance.interceptors.request.use((config:InternalAxiosRequestConfig)=>{
const user = auth.getUser()
if(user.token){
config.headers.Authorization = `Bearer ${ user.token}`
}
return config
},(err: AxiosError) => {
logger.error('Req Error', JSON.stringify(err))
return Promise.reject(err)
})
//3.配置響應(yīng)攔截器 后端給前端的東西
// instance.interceptors.response.use(()=>{成功} ,()=>{失敗})
//攔截器interceptors
//response通常指的是網(wǎng)絡(luò)請求的響應(yīng)。這是一個(gè)結(jié)構(gòu)體,用于封裝服務(wù)器返回的信息,
//AxiosResponse是Axios庫中的一個(gè)接口,用于表示HTTP響應(yīng)。以便開發(fā)者可以輕松地訪問響應(yīng)的各個(gè)部分。
instance.interceptors.response.use((res: AxiosResponse) => {
//成功
if (res.data.code === 10000) {
logger.debug('Req Success', JSON.stringify(res.data.data))
return res.data.data
}
//請求成功,回傳是錯誤的
logger.error('Req Error', JSON.stringify(res.data))
return Promise.reject(res.data)
}, (err: AxiosError) => {
//失敗返回的錯誤
logger.error('Req Error', JSON.stringify(err))
return Promise.reject(err)
})
//4.封裝Htpp類
// 提供request方法
class Http {
// Get 請求可以省略第二個(gè)泛型,因?yàn)閍xios默認(rèn)是any任何值可傳
//ResponseData 響應(yīng)數(shù)據(jù)類型 返回的數(shù)據(jù)(響應(yīng)回來的數(shù)據(jù))
//RequestData 請求數(shù)據(jù)類型 請求攜帶的參數(shù)
//Object 給個(gè)默認(rèn)值 有的是入?yún)?
//AxiosResponse是Axios庫中的一個(gè)接口,用于表示HTTP響應(yīng)。以便開發(fā)者可以輕松地訪問響應(yīng)的各個(gè)部分。
// request<T,D>
//T是自己的,D是請求得到
request<ResponseData, RequestData = Object>(config: AxiosRequestConfig<RequestData>) {
return instance<null, ResponseData, RequestData>(config)
}
}
//5.創(chuàng)建并導(dǎo)出 http實(shí)例對象
export const http = new Http()到此這篇關(guān)于鴻蒙中Axios數(shù)據(jù)請求的封裝和配置方法的文章就介紹到這了,更多相關(guān)鴻蒙 Axios數(shù)據(jù)請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
教你免費(fèi)做一個(gè)屬于自己穩(wěn)定有效的圖床-PicGo
由于現(xiàn)在很多寫作平臺都支持了Markdown語法,導(dǎo)致圖床用的人越來越多。這篇文章主要介紹了如何免費(fèi)做一個(gè)屬于自己穩(wěn)定有效的圖床-PicGo,需要的朋友可以參考下2020-01-01
gradle+shell實(shí)現(xiàn)自動系統(tǒng)簽名
這篇文章主要介紹了gradle+shell實(shí)現(xiàn)自動系統(tǒng)簽名的相關(guān)資料,需要的朋友可以參考下2019-08-08
asp php 清空access mysql mssql數(shù)據(jù)庫的代碼
php清空mysql asp情況access或mssql2008-12-12
最新Adobe2022?全家桶永久激活無限使用?附安裝包下載(一鍵安裝)
眾所周知,Adobe系列的軟件每年都會更新一個(gè)大版本,這不,2022年還沒到來,可Adobe2022已經(jīng)更新了,所以最新版一出來,就有安裝體驗(yàn),整體效果非常不錯,今天就把所有資源分享給大家2021-12-12
github版本庫使用詳細(xì)圖文教程(命令行及圖形界面版)
今天我們就來學(xué)習(xí)github的使用,我們將用它來管理我們的代碼,你會發(fā)現(xiàn)它的好處的,當(dāng)然是要在本系列教程全部完成之后,所以請緊跟站長的步伐,今天是第一天,我們來學(xué)習(xí)如何在git上建立自己的版本倉庫,并將代碼上傳到倉庫中2015-08-08
微信報(bào)警 zabbix實(shí)現(xiàn)詳解
這篇文章主要介紹了微信報(bào)警 zabbix方法的相關(guān)資料,需要的朋友可以參考下2016-09-09

