网络相关类组件
模块 | 介绍 |
---|---|
efAxiosParams | 提供eftool封装axios请求所需的参数 |
efAxios | 二次封装axios的产物,提供统一请求响应拦截等 |
efClientApi | 提供针对于统一post,get,delete,put等请求封装 |
网络组件使用API
前言
1.efAxiosParams类参数详解
/**
* 是否整体传输加密 与关键字加密isAllEncrypt互斥 二者只能有其一为true
*/
static isAllEncrypt: boolean = false;
/**
* 是否部分关键字传输加密 与整体传输加密互斥 二者只能有其一为true
*/
static isPartEncrypt: boolean = false;
/**
* 关键字加密时的关键字集合
*/
static keyWordsList: Array<string> = new Array<string>();
/**
* 用户自定义token的Key,默认为Authorization
*/
static tokenName: string = 'Authorization';
/**
* 登录成功后的token值
*/
static tokenValue: string = '';
/**
* 服务器 URL
*/
static baseURL: string = '';
/**
* 请求头加密的SM2公钥
*/
static sm2PubKey: string = '';
/**
*加解密接口忽略集合
*/
static ignoreEncryptList: Array<string> = new Array<string>();
/**
* 是否将响应数据转换为OutDTO对象,默认为true,如业务后台返回无法转换则关闭(1.1.9+)
*/
static isConvertDTO: boolean = true;
2.AxiosUtil工具类
- efAxios 全局对象
该变量为抛出的全局二次封装的全局axios对象,默认超时时间为10s
- convertRequestInfo 封装的针对于统一请求的处理
//1.统一给请求头添加nonce防篡改校验因子,业务自行实现,如有需求也可在后续demo中完善
//2.统一给请求头添加timestamp防重放的随机数因子,业务自行实现,如有需求也可在后续demo中完善
//3.设置默认请求类型 application/json
//4.添加统一的isAllEncrypt=true时整体加密,当前版本前端已完成,后端demo暂未完成,预计1.1.9前后可全部完善
//5.添加统一的isPartEncrypt=true时根据关键字加密,当前版本前端已完成,后端demo暂未完成,预计1.1.9前后可全部完善
//6.添加统一的请求头签名sign字段,当前版本前端已完成,后端demo暂未完成,预计1.1.9前后可全部完善
- convertResponseInfo 封装的针对于统一响应的处理 【统一返回OutDTO】
//新增efAxiosParams.isConvertDTO来根据业务需要自行决定是否开启封装返回数据为OutDTO
//目前只对返回数据格式做了统一的OutDTO转换
//要求后端返回的数据格式包含OutDTO中的success,msg
//dataRow和dataTable业务数据自行选择,非必填
3.EfClientApi工具类
该工具类提供统一简化各种请求方式,入参为json格式内部进行转换为所需对象
- post请求 async/await 方式
//参数说明
async post<F, E>(url: string, query: Record<string, Object>, headers?: Record<string, Object>): Promise<E>
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//F 为请求入参对象,具体参照示例中的写法
//E 为响应结果对象,格式为OutDTO<T> T为业务自定义对象
//headers提供给如果当前请求需要额外设置headers请求头参数时使用,保持json格式
//query 为JSON格式的请求参数key需要为字符串类型必须使用引号包裹 在方法内会将JSON转换为请求对象F,业务无需关心
- get请求 async/await 方式
//参数说明 格式为 getXXXX/id/name/xxxx
async get<E>(url: string): Promise<E>
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//注意demo中的get请求为rest方式,即入参无需?param1=value,而是 get方法/param1/param2 以此类推
//E 为响应结果对象,格式为OutDTO<T> T为业务自定义对象
- getByParams请求 async/await 方式 (1.1.9+)
//参数说明 参数为json格式
async getByParams<E>(url: string, params: Record<string, Object>): Promise<E>
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//params表示get请求的入参妇科key:value格式
//E 为响应结果对象,格式为OutDTO<T> T为业务自定义对象
- delete请求 async/await 方式
//参数说明
async delete<E>(url: string): Promise<E>
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//注意demo中的delete请求为rest方式,即入参方式为 delete方法/param1/param2 以此类推
//E 为响应结果对象,格式为OutDTO<T> T为业务自定义对象
- put请求 async/await 方式
//参数说明
put<F, E>(url: string, query: Record<string, Object>): Promise<E>
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//F 为请求入参对象,具体参照示例中的写法
//E 为响应结果对象,格式为OutDTO<T> T为业务自定义对象
//query 为JSON格式的请求参数key需要为字符串类型必须使用引号包裹 在方法内会将JSON转换为请求对象F,业务无需关心
- upload 统一的上传请求 async/await 方式 (1.1.10+)
//参数说明
async upload(url: string, isUri: boolean, progressCallBack: (process: number) => void, data?: ArrayBuffer, uri?: string, fileName?: string)
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//progressCallBack 上传进度回调,具体参照示例中的写法
//isUri 是否为uri文件
//data isUri=false时传入 表示上传的文件为ArrayBuffer格式
//uri isUri=true时传入 表示上传的文件为uri格式
//fileName 上传时后端接收的key,默认为file
- download 统一的下载请求 async/await 方式 (1.1.10+)
//参数说明
async download(url: string, filePath: string, progressCallBack: (process: number) => void)
//url 为请求方法的url 全路径应该为 efAxiosParams.baseURL+url 组合而成
//filePath 下载文件名称 如下载png图片后希望名称为girl.png
//progressCallBack 下载进度回调方法
- 登录示例
//如果不需要响应数据转换为OutDTO则将efAxiosParams.isConvertDTO设置为false
efAxiosParams.isConvertDTO = false;
const loginNoDTO = await efClientApi.post<UserQuery,UserDTO>('/api/eftool/login', {
'account': 'efadmin',
'pwd': '123456'
}, {
'csxTest': '1212121212'
});
if (loginNoDTO.token) {
ToastUtil.showToast('登录成功,token为:'+loginNoDTO.token);
}
//1.先设置统一的请求后端前缀 具体时机业务自行决定,Ability中也可
efAxiosParams.baseURL = 'http://192.168.1.126:18088';
//2.调用接口
//模拟登录 UserQuery为请求参数,OutDTO<UserDTO>为响应的结果,OutDTO中的对象为业务自己创建
const login = await efClientApi.post<UserQuery, OutDTO<UserDTO>>('/api/eftool/login', {
'account': 'efadmin',
'pwd': '123456'
}, {
'testAddHeader': '1212121212' //此处表示当前请求会额外将testAddHeader添加到请求头中
});
//登录成功
if (login.getSuccess()) {
//登录成功将token赋值,后续需要,默认token的key为Authorization
//如果需要更换业务调用efAxiosParams.tokenName = '业务自定义的token名称'
efAxiosParams.tokenName = '如此处更换为efToken';
efAxiosParams.tokenValue = login.getDataRow().token;
} else {
//登录失败
ToastUtil.showToast(login.getMsg());
}
- post示例
//模拟测试post请求 此时的请求头中已经存在token字段
//UserQuery为请求参数,OutDTO<Record<string, Object>>为响应的结果,OutDTO中的对象为业务自己创建
const post = await efClientApi.post<UserQuery, OutDTO<Record<string, Object>>>('/api/eftool/post', {
'nickName': 'post请求参数',
'name': '测试入参'
});
if (post.getSuccess()) {
ToastUtil.showToast(JSONUtil.toJSONString(post.getDataRow()));
}
- get示例
//模拟测试get请求
//OutDTO<Record<string, Object>>为响应的结果,OutDTO中的对象为业务自己创建
const get = await efClientApi.get<OutDTO<Record<string, Object>>>('/api/eftool/get/11111111');
if (get.getSuccess()) {
ToastUtil.showToast(JSONUtil.toJSONString(get.getDataRow()));
}
- put示例
//模拟测试put请求
//UserQuery为请求参数,OutDTO<Record<string, Object>>为响应的结果,OutDTO中的对象为业务自己创建
const put = await efClientApi.put<UserQuery, OutDTO<Record<string, Object>>>('/api/eftool/put', {
'id': '11111'
});
if (put.getSuccess()) {
ToastUtil.showToast(JSONUtil.toJSONString(put.getDataRow()));
}
- delete示例
//模拟测试delete请求
//OutDTO<Record<string, Object>>为响应的结果,OutDTO中的对象为业务自己创建
const del = await efClientApi.delete<OutDTO<Record<string, Object>>>('/api/eftool/delete/1212133');
if (del.getSuccess()) {
ToastUtil.showToast(JSONUtil.toJSONString(del.getDataRow()));
}
- 上传示例 (1.1.10+)
//模拟文件上传
async testUpload() {
this.showDownBtn = Visibility.Visible;
efAxiosParams.baseURL = 'http://192.168.1.126:18088';
let ctx = getContext() as common.UIAbilityContext;
let imageArray = await ctx.resourceManager.getMediaContent($r('app.media.notice').id);
let imageResource = imageArray.buffer as ArrayBuffer;
let res = await efClientApi.upload('/api/eftool/upload', false, (progress: number) => {
if (progress >= 100) {
this.showDownBtn = Visibility.None;
}
this.process = progress;
}, imageResource);
this.msg = res ? res["dataRow"] : '';
}
- 下载示例 (1.1.10+)
//模拟测试文件下载
async testDownload() {
efAxiosParams.baseURL = 'http://192.168.1.126:18088';
this.showDownBtn = Visibility.Visible;
let res = await efClientApi.download('/api/eftool/download/0d6a25e4-f61b-48eb-8a12-53f82c5b957d-default1715324534920.png', 'girl.png', (progress: number) => {
if (progress >= 100) {
this.showDownBtn = Visibility.None;
}
this.process = progress;
});
this.msg = res ? res["msg"] : '';
}
最后
有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)资料用来跟着学习是非常有必要的。
点击领取→【纯血版鸿蒙全套最新学习资料】(安全链接,放心点击)希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!
这份鸿蒙(HarmonyOS NEXT)资料包含了鸿蒙开发必掌握的核心知识要点,内容包含了(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、(南向驱动、嵌入式等)鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)技术知识点。
鸿蒙(HarmonyOS NEXT)最新学习路线
有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模型、资源分类…等知识点。
获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料
HarmonyOS Next 最新全套视频教程
《鸿蒙 (OpenHarmony)开发基础到实战手册》
OpenHarmony北向、南向开发环境搭建
《鸿蒙开发基础》
- ArkTS语言
- 安装DevEco Studio
- 运用你的第一个ArkTS应用
- ArkUI声明式UI开发
- .……
《鸿蒙开发进阶》
- Stage模型入门
- 网络管理
- 数据管理
- 电话服务
- 分布式应用开发
- 通知与窗口管理
- 多媒体技术
- 安全技能
- 任务管理
- WebGL
- 国际化开发
- 应用测试
- DFX面向未来设计
- 鸿蒙系统移植和裁剪定制
- ……
《鸿蒙进阶实战》
- ArkTS实践
- UIAbility应用
- 网络案例
- ……
大厂面试必问面试题
鸿蒙南向开发技术
鸿蒙APP开发必备
鸿蒙生态应用开发白皮书V2.0PDF
总结
总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑战,也是一个机会。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的时代中立于不败之地。