Okhttp.ets
/**
* 網絡請求
*/
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'
// 創建axios實例
const service = axios.create({
baseURL:httpConstants.url,
timeout:10000
})
// request攔截器
service.interceptors.request.use(async config = > {
// 是否需要設置 token
const access_token = await SPUtils.get(SpConstants.accessToken,"")
if (access_token != "") {
config.headers['Authorization'] = 'Bearer ' + access_token // 讓每個請求攜帶自定義token 請根據實際情況自行修改
}
return config
}, error = > {
console.log(error)
Promise.reject(error)
})
// 響應攔截器
service.interceptors.response.use(res = > {
// 未設置狀態碼則默認成功狀態
const code = res.data.code || 200;
// 獲取錯誤信息
const msg = errorCode[code] || res.data.msg || errorCode['default']
if (code === 401) {
toast.show("登錄狀態已過期,您可以繼續留在該頁面,或者重新登錄")
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 = "系統接口請求超時";
}
else if (message.includes("Request failed with status code")) {
message = "系統接口" + message.substr(message.length - 3) + "異常";
}
toast.show(message)
return Promise.reject(error)
}
)
export default service
API接口調用方法
LoginAPI.ets
或+mau123789學習,是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
})
}
// 獲取用戶詳細信息-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)
})
審核編輯 黃宇
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
鴻蒙OS
+關注
關注
0文章
190瀏覽量
4537
發布評論請先 登錄
相關推薦
如何調試 HTTP 請求和響應
調試HTTP請求和響應是Web開發和網絡編程中的一個重要技能。以下是一些步驟和工具,可以幫助你調試HTTP請求和響應: 1. 使用瀏覽器開發者工具 大多數現代瀏覽器都內置了開發者工具,這些工具可以
鴻蒙Flutter實戰:14-現有Flutter 項目支持鴻蒙 II
分別安裝官方的3.22版本,以及鴻蒙社區的 3.22.0 版本
3.搭建 Flutter鴻蒙開發環境
參考文章《鴻蒙Flutter實戰:01-搭建開發環境》
搭建項目架構
創建目錄
發表于 12-26 14:59
Python編程:處理網絡請求的代理技術
在網絡編程中,代理技術扮演著至關重要的角色,尤其在處理網絡請求時。通過代理服務器,我們可以實現請求的轉發、緩存、負載均衡以及安全控制等功能。Python作為一種功能強大的編程語言,為提
HDC2024華為發布鴻蒙原生智能:AI與OS深度融合,開啟全新的AI時代
6月21日,華為開發者大會2024(HDC.2024)召開。 HarmonyOS NEXT將AI與OS深度融合,構筑全新鴻蒙原生智能框架。大會現場,華為常務董事、終端BG董事長、智能汽車解決方案BU
Android項目轉為鴻蒙,真就這么簡單?
?最近做了一個有關Android轉換成鴻蒙的項目。**經不少開發者的反饋;許多公司的業務都增加了鴻蒙板塊。** 對此想分享一下這個項目轉換的流程結構,希望能夠給大家在工作中帶來一些幫助。
鴻蒙OS崛起,鴻蒙應用開發工程師成市場新寵
應用的形態也在發生著翻天覆地的變化。作為全球領先的移動操作系統和智能終端制造商,華為公司自主研發的鴻蒙OS應運而生,致力于構建一個統一的分布式操作系統,為各行各業的應用開發帶來全新的可能性。
一、鴻蒙
發表于 04-29 17:32
鴻蒙OS開發實例:【窺探網絡請求】
HarmonyOS 平臺中使用網絡請求,需要引入 "@ohos.net.http", 并且需要在 module.json5 文件中申請網絡權限, 即 “ohos.permission.INTERNET”
本篇文章將嘗試使用
鴻蒙原生應用開發-網絡管理HTTP數據請求
request請求先返回。可以根據業務需要訂閱此消息。
4.調用該對象的request()方法,傳入http請求的url地址和可選參數,發起網絡請求。
5.按照實際業務需要,解析返回結
發表于 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版本進行適配,使其可以運行在 OpenHarmo
2024款鴻蒙OS 最新HarmonyOS Next_HarmonyOS4.0系列教程分享
了有關華為鴻蒙的課程,包括清華大學、武漢大學、哈爾濱工業大學等等。據香港《南華早報》報道,當地時間1月3日,加拿大市場研究與咨詢機構TechInsights發布按照操作系統(OS)劃分的全球智能手機銷售
發表于 02-28 10:29
純血鴻蒙系統,拿什么與安卓、iOS比?
ArkUI
……
2、鴻蒙進階
Stage模型
網絡、數據管理
一次開發多段部署
……
3、鴻蒙多媒體技術
音頻
視頻
相機
圖片
……
4、鴻蒙
發表于 02-21 21:04
鴻蒙OS之UI架構解析
發送get請求,然后更新articles數組。
aboutToAppear() {
// 請求網絡數據
axios.get(url).then(response => {
//
發表于 02-20 15:36
評論