Okhttp.ets
/**
* 網(wǎng)絡(luò)請求
*/
import axios from '@ohos/axios'
import httpConstants from '../net/HttpConstants'
import errorCode from '../utils/errorCode'
import toast from '../utils/ToastUtils'
import router from '../utils/RouterUtils'
import SPUtils from '../utils/SPUtils'
import SpConstants from '../net/SpConstants'
axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8'
// 創(chuàng)建axios實(shí)例
const service = axios.create({
baseURL:httpConstants.url,
timeout:10000
})
// request攔截器
service.interceptors.request.use(async config = > {
// 是否需要設(shè)置 token
const access_token = await SPUtils.get(SpConstants.accessToken,"")
if (access_token != "") {
config.headers['Authorization'] = 'Bearer ' + access_token // 讓每個(gè)請求攜帶自定義token 請根據(jù)實(shí)際情況自行修改
}
return config
}, error = > {
console.log(error)
Promise.reject(error)
})
// 響應(yīng)攔截器
service.interceptors.response.use(res = > {
// 未設(shè)置狀態(tài)碼則默認(rèn)成功狀態(tài)
const code = res.data.code || 200;
// 獲取錯(cuò)誤信息
const msg = errorCode[code] || res.data.msg || errorCode['default']
if (code === 401) {
toast.show("登錄狀態(tài)已過期,您可以繼續(xù)留在該頁面,或者重新登錄")
router.goNot('pages/Login')
} else if (code === 500) {
toast.show(msg)
return Promise.reject(new Error(msg))
} else if (code !== 200) {
toast.show(msg)
return Promise.reject('error')
} else {
return res
}
},
error = > {
console.log('err' + error)
let { message } = error;
if (message == "Network Error") {
message = "后端接口連接異常";
}
else if (message.includes("timeout")) {
message = "系統(tǒng)接口請求超時(shí)";
}
else if (message.includes("Request failed with status code")) {
message = "系統(tǒng)接口" + message.substr(message.length - 3) + "異常";
}
toast.show(message)
return Promise.reject(error)
}
)
export default service
API接口調(diào)用方法
LoginAPI.ets
或+mau123789學(xué)習(xí),是v喔
import okHttp from '../utils/Okhttp'
// 登錄方法-POST方法
export function login(username, password, code, uuid) {
const data = {
username,
password,
code,
uuid
}
return okHttp({
url: '/login',
method: 'post',
data: data
})
}
// 獲取用戶詳細(xì)信息-GET方法
export function getInfo() {
return okHttp({
url: '/getInfo',
method: 'get'
})
}
Login.ets頁面
import {login,getInfo} from '../api/LoginAPI'
login(this.userName,this.userPwd,this.userCode,this.uuid).then(res= >{
SPUtils.put(SpConstants.appUser,this.userName)
SPUtils.put(SpConstants.appPwd,this.userPwd)
SPUtils.put(SpConstants.accessToken,res.data.token)
})
審核編輯 黃宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
-
鴻蒙OS
+關(guān)注
關(guān)注
0文章
188瀏覽量
4382
發(fā)布評(píng)論請先 登錄
相關(guān)推薦
Python編程:處理網(wǎng)絡(luò)請求的代理技術(shù)
在網(wǎng)絡(luò)編程中,代理技術(shù)扮演著至關(guān)重要的角色,尤其在處理網(wǎng)絡(luò)請求時(shí)。通過代理服務(wù)器,我們可以實(shí)現(xiàn)請求的轉(zhuǎn)發(fā)、緩存、負(fù)載均衡以及安全控制等功能。Python作為一種功能強(qiáng)大的編程語言,為提
鴻蒙OS崛起,鴻蒙應(yīng)用開發(fā)工程師成市場新寵
應(yīng)用的形態(tài)也在發(fā)生著翻天覆地的變化。作為全球領(lǐng)先的移動(dòng)操作系統(tǒng)和智能終端制造商,華為公司自主研發(fā)的鴻蒙OS應(yīng)運(yùn)而生,致力于構(gòu)建一個(gè)統(tǒng)一的分布式操作系統(tǒng),為各行各業(yè)的應(yīng)用開發(fā)帶來全新的可能性。
一、鴻蒙
發(fā)表于 04-29 17:32
鴻蒙OS開發(fā)實(shí)例:【HarmonyHttpClient】網(wǎng)絡(luò)框架
鴻蒙上使用的Http網(wǎng)絡(luò)框架,里面包含純Java實(shí)現(xiàn)的HttpNet,類似okhttp使用,支持同步和異步兩種請求方式;還有
鴻蒙OS開發(fā)實(shí)戰(zhàn):【網(wǎng)絡(luò)管理HTTP數(shù)據(jù)請求】
應(yīng)用通過HTTP發(fā)起一個(gè)數(shù)據(jù)請求,支持常見的GET、POST、OPTIONS、HEAD、PUT、DELETE、TRACE、CONNECT方法。
鴻蒙OS開發(fā)實(shí)例:【窺探網(wǎng)絡(luò)請求】
HarmonyOS 平臺(tái)中使用網(wǎng)絡(luò)請求,需要引入 "@ohos.net.http", 并且需要在 module.json5 文件中申請網(wǎng)絡(luò)權(quán)限, 即 “ohos.permission.INTERNET”
本篇文章將嘗試使用
鴻蒙原生應(yīng)用開發(fā)-網(wǎng)絡(luò)管理HTTP數(shù)據(jù)請求
request請求先返回。可以根據(jù)業(yè)務(wù)需要訂閱此消息。
4.調(diào)用該對象的request()方法,傳入http請求的url地址和可選參數(shù),發(fā)起網(wǎng)絡(luò)請求。
5.按照實(shí)際業(yè)務(wù)需要,解析返回結(jié)
發(fā)表于 03-29 17:51
鴻蒙OS開發(fā)實(shí)例:【工具類封裝-http請求】
;@ohos.promptAction';**
**封裝HTTP接口請求類,提供格式化的響應(yīng)信息輸出功能。
使用 DevEco Studio 3.1.1 Release 及以上版本,API 版本為 api 9 及以上
鴻蒙開發(fā)實(shí)戰(zhàn):網(wǎng)絡(luò)請求庫【axios】
[Axios]?,是一個(gè)基于 promise 的網(wǎng)絡(luò)請求庫,可以運(yùn)行 node.js 和瀏覽器中。本庫基于[Axios]原庫v1.3.4版本進(jìn)行適配,使其可以運(yùn)行在 OpenHarmo
2024款鴻蒙OS 最新HarmonyOS Next_HarmonyOS4.0系列教程分享
了有關(guān)華為鴻蒙的課程,包括清華大學(xué)、武漢大學(xué)、哈爾濱工業(yè)大學(xué)等等。據(jù)香港《南華早報(bào)》報(bào)道,當(dāng)?shù)貢r(shí)間1月3日,加拿大市場研究與咨詢機(jī)構(gòu)TechInsights發(fā)布按照操作系統(tǒng)(OS)劃分的全球智能手機(jī)銷售
發(fā)表于 02-28 10:29
鴻蒙OS之UI架構(gòu)解析
發(fā)送get請求,然后更新articles數(shù)組。
aboutToAppear() {
// 請求網(wǎng)絡(luò)數(shù)據(jù)
axios.get(url).then(response => {
//
發(fā)表于 02-20 15:36
跨Android、iOS、鴻蒙多平臺(tái)框架ArkUI-X
在Android、iOS、鴻蒙多個(gè)平臺(tái)上提供生動(dòng)而流暢的用戶界面體驗(yàn)。 一、配套關(guān)系 表1 版本軟件和平臺(tái)配套關(guān)系 目標(biāo)平臺(tái) 項(xiàng)目編譯使用OS SDK版本 備注 OpenHarmony 4.0 (API
鴻蒙OS和開源鴻蒙什么關(guān)系?
內(nèi)核,其他功能都以模塊的形式存在。 ? ? 華為用的是鴻蒙OS 我們都知道,華為手機(jī)的鴻蒙OS是可以運(yùn)行安卓軟件的,是因?yàn)橄到y(tǒng)中有安卓兼容層,所以可以簡單這么理解:
OpenHarmony:使用網(wǎng)絡(luò)組件axios與Spring Boot進(jìn)行前后端交互
這兩個(gè)函數(shù)是使用axios庫發(fā)起HTTP GET請求的函數(shù),用于與服務(wù)器進(jìn)行通信
1月18號(hào)“純鴻蒙”千帆啟航,程序員預(yù)備!
……
《鴻蒙開發(fā)進(jìn)階》http://qr61.cn/oWQPaX/qU3VHZO
1.Stage模型入門
2.網(wǎng)絡(luò)管理
3.數(shù)據(jù)管理
4.電話服務(wù)
5.分布式應(yīng)用開發(fā)
6.通知與窗口
發(fā)表于 01-16 22:13
鴻蒙Harmony是如何影響Android工程師的呢?
其實(shí)鴻蒙在2019就已經(jīng)出來了,那時(shí)候還是套殼Android的。從2023年9月的發(fā)布會(huì)上,華為宣布鴻蒙原生應(yīng)用全面啟動(dòng)、HarmonyOS NEXT亮相以后,圍繞著純血鴻蒙展開的
發(fā)表于 01-14 22:14
評(píng)論