百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

鸿蒙中封装持久化工具和Axios(鸿蒙工具箱4.0官网下载中文版)

liuian 2025-03-25 15:21 13 浏览


封装持久化:

1.定义一个专门持久化读写user模块的类

// 持久化存储

export class UserSetting {


}


// 暴露实例

export const userSetting = new UserSetting()

2.使用PersistentStorage持久化,在类中定义initSetting方法统一管理

import { TOKEN_KEY, USER_INFO } from '../constants' // key常量

import { UserInfoClass } from '../viewmodels'


// 持久化存储

export class UserSetting {

// 持久化存储

initSetting() {


PersistentStorage.persistProp(USER_INFO, {}) // 用户信息

PersistentStorage.persistProp(TOKEN_KEY, '') // token

// ... 有就在加

}

}

3.使用AppStorage.get获取数据,在类中分别定义get方法

import { TOKEN_KEY, USER_INFO } from '../constants' // key常量

import { UserInfoClass } from '../viewmodels'


// 持久化存储

export class UserSetting {

// 获取用户信息

getUser(): UserInfoClass {

return AppStorage.get(USER_INFO) as UserInfoClass

}

// 获取token

getToken(): string {

return AppStorage.get(TOKEN_KEY) as string

}

}

4.使用AppStorage.set存储数据,在类中分别定义set方法

import { TOKEN_KEY, USER_INFO } from '../constants' // key常量

import { UserInfoClass } from '../viewmodels'


// 持久化存储

export class UserSetting {

// 设置存储

setUser(user: UserInfoClass) {

AppStorage.set(USER_INFO, user)

}

// 设置token

setToken(token: string) {

AppStorage.set(TOKEN_KEY, token)

}

}

5.整体代码:

import { TOKEN_KEY, USER_INFO } from '../constants'

import { UserInfoClass } from '../viewmodels'


// 封装存储

export class UserSetting {

// 持久化存储

initSetting() {


PersistentStorage.persistProp(USER_INFO, {}) // 用户信息

PersistentStorage.persistProp(TOKEN_KEY, '') // token

// ... 有就在加

}


// 用户信息
-------------------------------------

// 获取

getSetting(): UserInfoClass{

return AppStorage.get(USER_INFO) as UserInfoClass

}

// 设置

setSetting(user: UserInfoClass) {

AppStorage.set(USER_INFO, user)

}

// token --------------------------------------

// 获取token

getToken(): string {

return AppStorage.get(TOKEN_KEY) as string

}

// 设置token

setToken(token: string) {

AppStorage.set(TOKEN_KEY, token)

}

// ------ 有就在加

}

// 导出

export const userSetting = new UserSetting()

注意:要在使用AppStorage之前,UI实例初始化成功后,调用PersistentStorage进行初始化,这样才能将AppStorage中key对应的属性持久化到文件中,我是直接在加载页面的回调中调用的。

封装axios:

1. 要先安装啊

ohpm install @ohos/axios

2. 创建axios实例

如果一个项目向多台服务器发送请求,我们就可以用create创建多个实例配置多个服务器的基地址,这就是为甚用create,方便咱们的项目延展

// 创建axios实例

const instance = axios.create({

baseURL: BASE_URL, // 基地址

timeout: 10000 // 超时时间

})

3. 配置请求拦截器

// 请求拦截器

instance.interceptors.request.use((config: InternalAxiosRequestConfig) => {

const token = userSetting.getToken() // 用刚刚封装的工具获取token

if (token) {

// 请求头添加token

config.headers.Authorization = token

}

return config // 返回配置

}, (error: AxiosError) => {

promptAction.showToast({ message: error.message })

return Promise.reject(error)

})

4. 配置响应拦截器

在这个项目中,只有当后台返回的状态码为200时,才是真正的成功,其他情况就抛出错误,状态码为401则是token超时,404则是地址错误,具体情况要看自家后端。

// 响应拦截器

instance.interceptors.response.use((response: AxiosResponse) => {

// 判断业务状态码

if (response.data && response.data.code === 200) {

return response.data.data

}

promptAction.showToast({ message: response.data.msg }) // 弹出错误消息

return Promise.reject(new Error(response.data.msg))


}, (error: AxiosError) => {

// 响应失败

if (error.response?.status === 401) {

promptAction.showToast({ message: '请登录' })

// 删除token

userSetting.setToken('') // 删除token

// 跳转到登录页

router.replaceUrl({

url: 'pages/Login/Login'

})

// 返回失败

return Promise.reject(new Error("登录失败"))

} else if (error.response?.status === 404) {

promptAction.showToast({ message: '请求地址错误' })

return Promise.reject(new Error("请求地址错误"))

}

promptAction.showToast({ message: error.message })

return Promise.reject(error)

})

5. 在封装一层方便咱们用

// 封装axios

class Http {

// 万能请求 -> 针对于复杂的场景,比如又传params又传data的。因为在响应拦截器中扒了两层data,

// 所以类型就不用再用AxiosResponse<后台返回数据<具体数据>>包了,直接写传过来的类型即可

request(config: AxiosRequestConfig) {

return instance.request(config)

}

// 封装get请求

get(url: string, params?: Data): Promise {

return this.request({

url,

method: 'GET',

params

})

}

// 封装post请求

post(url: string, data?: Data): Promise {

return this.request({

url,

method: 'POST',

data

})

}

// 封装delete请求

delete(url: string, params?: Data): Promise {

return this.request({

url,

method: 'DELETE',

params

})

}

// 封装put请求

put(url: string, data?: Data): Promise {

return this.request({

url,

method: 'PUT',

data

})

}

}


// 导出封装类

export const myHttp = new Http()

6.整体代码:

import axios, { AxiosError, AxiosRequestConfig, AxiosResponse, InternalAxiosRequestConfig } from '@ohos/axios'

import { userSetting } from '.'

import { BASE_URL } from '../constants'

import { promptAction, router } from '@kit.ArkUI'


// 创建axios实例

const instance = axios.create({

baseURL: BASE_URL, // 设置基础地址

timeout: 10000

})


// 请求拦截器

instance.interceptors.request.use((config: InternalAxiosRequestConfig) => {

const token = userSetting.getToken() // 获取token

if (token) {

// 请求头添加token

config.headers.Authorization = token

}

return config // 返回配置

}, (error: AxiosError) => {

promptAction.showToast({ message: error.message })

return Promise.reject(error)

})


// 响应拦截器

instance.interceptors.response.use((response: AxiosResponse) => {

// 判断业务状态码

if (response.data && response.data.code === 200) {

return response.data.data

}

promptAction.showToast({ message: response.data.msg }) // 弹出错误消息

return Promise.reject(new Error(response.data.msg))



}, (error: AxiosError) => {

// 响应失败

if (error.response?.status === 401) {

promptAction.showToast({ message: '登录失败' })

// 删除token

userSetting.setToken('') // 清空token

// 跳转到登录页

router.replaceUrl({

url: 'pages/Login/Login'

})

// 返回失败

return Promise.reject(new Error("登录失败"))

} else if (error.response?.status === 404) {

promptAction.showToast({ message: '请求地址错误' })

return Promise.reject(new Error("请求地址错误"))

}

promptAction.showToast({ message: error.message })

return Promise.reject(error)

})


// 封装axios

class Http {

// 万能请求

request(config: AxiosRequestConfig) {

return instance.request(config)

}

// 封装get请求

get(url: string, params?: Data): Promise {

return this.request({

url,

method: 'GET',

params

})

}

// 封装post请求

post(url: string, data?: Data): Promise {

return this.request({

url,

method: 'POST',

data

})

}

// 封装delete请求

delete(url: string, params?: Data): Promise {

return this.request({

url,

method: 'DELETE',

params

})

}

// 封装put请求

put(url: string, data?: Data): Promise {

return this.request({

url,

method: 'PUT',

data

})

}

}


// 导出封装类

export const myHttp = new Http()

相关推荐

GANs为何引爆机器学习?这篇基于TensorFlow的实例教程为你解惑!

「机器人圈导览」:生成对抗网络无疑是机器学习领域近三年来最火爆的研究领域,相关论文层出不求,各种领域的应用层出不穷。那么,GAN到底如何实践?本文编译自Medium,该文作者以一朵玫瑰花为例,详细阐...

高丽大学等机构联合发布StarGAN:可自定义表情和面部特征

原文来源:arXiv、GitHub作者:YunjeyChoi、MinjeChoi、MunyoungKim、Jung-WooHa、SungKim、JaegulChoo「雷克世界」编译:嗯~...

TensorFlow和PyTorch相继发布最新版,有何变化

原文来源:GitHub「机器人圈」编译:嗯~阿童木呀、多啦A亮Tensorflow主要特征和改进在Tensorflow库中添加封装评估量。所添加的评估量列表如下:1.深度神经网络分类器(DNNCl...

「2022 年」崔庆才 Python3 爬虫教程 - 深度学习识别滑动验证码缺口

上一节我们使用OpenCV识别了图形验证码躯壳欧。这时候就有朋友可能会说了,现在深度学习不是对图像识别很准吗?那深度学习可以用在识别滑动验证码缺口位置吗?当然也是可以的,本节我们就来了解下使用深度...

20K star!搞定 LLM 微调的开源利器

LLM(大语言模型)微调一直都是老大难问题,不仅因为微调需要大量的计算资源,而且微调的方法也很多,要去尝试每种方法的效果,需要安装大量的第三方库和依赖,甚至要接入一些框架,可能在还没开始微调就已经因为...

大模型DeepSeek本地部署后如何进行自定义调整?

1.理解模型架构a)查看深度求索官方文档或提供的源代码文件,了解模型的结构、输入输出格式以及支持的功能。模型是否为预训练权重?如果是,可以在预训练的基础上进行微调(Fine-tuning)。是否需要...

因配置不当,约5000个AI模型与数据集在公网暴露

除了可访问机器学习模型外,暴露的数据还可能包括训练数据集、超参数,甚至是用于构建模型的原始数据。前情回顾·人工智能安全动态向ChatGPT植入恶意“长期记忆”,持续窃取用户输入数据多模态大语言模型的致...

基于pytorch的深度学习人员重识别

基于pytorch的深度学习人员重识别Torchreid是一个库。基于pytorch的深度学习人员重识别。特点:支持多GPU训练支持图像的人员重识别与视频的人员重识别端到端的训练与评估简单的re...

DeepSeek本地部署:轻松训练你的AI模型

引言:为什么选择本地部署?在AI技术飞速发展的今天,越来越多的企业和个人希望将AI技术应用于实际场景中。然而,对于一些对数据隐私和计算资源有特殊需求的用户来说,云端部署可能并不是最佳选择。此时,本地部...

谷歌今天又开源了,这次是Sketch-RNN

前不久,谷歌公布了一项最新技术,可以教机器画画。今天,谷歌开源了代码。在我们研究其代码之前,首先先按要求设置Magenta环境。(https://github.com/tensorflow/magen...

Tensorflow 使用预训练模型训练的完整流程

前面已经介绍了深度学习框架Tensorflow的图像的标注和训练数据的准备工作,本文介绍一下使用预训练模型完成训练并导出训练的模型。1.选择预训练模型1.1下载预训练模型首先需要在Tensorf...

30天大模型调优学习计划(30分钟训练大模型)

30天大模型调优学习计划,结合Unsloth和Lora进行大模型微调,掌握大模型基础知识和调优方法,熟练应用。第1周:基础入门目标:了解大模型基础并熟悉Unsloth等工具的基本使用。Day1:大模...

python爬取喜马拉雅音频,json参数解析

一.抓包分析json,获取加密方式1.抓包获取音频界面f12打开抓包工具,播放一个(非vip)视频,点击“媒体”单击打开可以复制URL,发现就是我们要的音频。复制“CKwRIJEEXn-cABa0Tg...

五、JSONPath使用(Python)(json数据python)

1.安装方法pipinstalljsonpath2.jsonpath与Xpath下面表格是jsonpath语法与Xpath的完整概述和比较。Xpathjsonpath概述/$根节点.@当前节点...

Python网络爬虫的时候json=就是让你少写个json.dumps()

大家好,我是皮皮。一、前言前几天在Python白银交流群【空翼】问了一个Python网络爬虫的问题,提问截图如下:登录请求地址是这个:二、实现过程这里【甯同学】给了一个提示,如下所示:估计很多小伙伴和...