harmonyOS HTTP数据请求能用类

通用类

import http from '@ohos.net.http';// 调试开关
const Test: boolean = true;// API 地址
const Url: string = Test ? 'http://api.林.cn/' : 'http://api.林.cn/';export function request(api: string, method: string, data: any, token: string = ''): Promise<any> {return new Promise((resolve, reject) => {// 构建完整的 URLconst url = Url + api;// 创建 http 模块实例const httpRequest = http.createHttp();// 根据 'method' 参数确定请求方法const requestMethod = getRequestMethod(method);// 要添加的额外标头const customHeaders = {'Content-Type': 'application/json','Authorization': token // 在这里添加您的自定义标头};// 发起 HTTP 请求const promise = httpRequest.request(url,{method: requestMethod,extraData: data,connectTimeout: 60000, // 60 秒readTimeout: 60000,header: { ...customHeaders } // 扩展自定义标头});// 处理 Promise 的解析promise.then((responseData) => {if (responseData.responseCode === http.ResponseCode.OK) {resolve(responseData); // 使用响应数据解析 Promise} else {console.error('错误 - 响应代码: ' + responseData.responseCode);reject(new Error('HTTP 请求失败,响应代码为 ' + responseData.responseCode));}}).catch((error) => {console.error('错误: ' + JSON.stringify(error));reject(error); // 使用错误拒绝 Promise});});
}// 辅助函数,将方法字符串映射到 http.RequestMethod
function getRequestMethod(method: string): http.RequestMethod {switch (method.toLowerCase()) {case 'get':return http.RequestMethod.GET;case 'post':return http.RequestMethod.POST;case 'put':return http.RequestMethod.PUT;case 'delete':return http.RequestMethod.DELETE;// 针对其他 HTTP 方法需要添加更多的情况default:throw new Error(`不支持的 HTTP 方法: ${method}`);}
}

调用方式


import { request } from '../tools/httpUtils';
@Entry //入口
@Component  //装饰
struct Index {@State message: string = '啾啾救援' //双向绑定build() {Row() {Column() {Image("http://www.jjsos.cn/images/menu_logo.png").width(300).interpolation(ImageInterpolation.High)Text(this.message).fontSize(50).fontWeight(FontWeight.Bold)Button('确定').fontSize(30).backgroundColor("#000").onClick(()=>{this.message="JJSOS"})TextInput({placeholder:'用户名'}).type(InputType.PhoneNumber)TextInput({placeholder:'密码'}).type(InputType.Password)Button('确定登陆').onClick(()=>{const requestData = {"type": "1","username": "13176630659","password": "123456"};const  authToken:string=""const apiEndpoint = 'v2/auth/get-access-token';request(apiEndpoint, 'post', requestData, authToken).then((responseData) => {// 这时写代码 console.log('Response:', responseData);// Perform actions based on the response}).catch((error) => {// Handle errorsconsole.error('Error:', error);// Perform error-specific actions});})}.width('100%').backgroundColor("#aaa")}.height('100%').backgroundColor("#aaa")}
}function authToken(apiEndpoint: string,arg1: string,requestData: { type: string; username: string; password: string; },authToken: any) {
throw new Error('Function not implemented.');
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/217283.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux下的网络服务

一般来说&#xff0c;各种操作系统在网络方面的性能比较是这样的顺序BSD>Linux>Win NT>Win 9X, 由此说来&#xff0c;Linux的网络功能仅次于UNIX&#xff0c;而强于Win NT和其它的视窗系列产品&#xff0c;对于Win2000我还不能评价太多&#xff0c;因为不是很熟。 Lin…

Android audio设置投屏和喇叭双输出

业务场景&#xff1a; 在 Android13 平台上&#xff0c;使用 USB 投屏工具scrcpy&#xff0c;投屏到电脑端时&#xff0c;声音被截到 电脑端播放&#xff0c;Android设备 端静音&#xff0c;在Android11及之前都是 在Android设备端正常播放。 分析&#xff1a; scrcpy 支持 …

数据结构 | 大根堆

思维导图 代码 #include<stdio.h> #include<iostream> using namespace std; void HeapAdjust(int* arr, int start, int end) {int temp arr[start];for (int i 2 * start 1; i < end; i 2 * i 1) //end可以取到等于 因为它是最后一个元素{if (i<end…

Spring boot注解

1.RestController RestController 注解用于标识一个类,表示该类的所有方法都返回JSON或XML响应&#xff0c;而不是视图页面。它是Controller和ResponseBody的组合 2.RequestMapping RequestMapping 注解用于映射HTTP请求到控制器方法或类。它可以用于类级别和方法级别,用于定…

UI5 development on VS Studio code

今天来分享一下如何VS studio code 上UI5开发环境的搭建 1.安装Node.js 路径&#xff1a;Node.js 因安装步骤较为简单&#xff0c;故不在此赘述。 验证方法如下&#xff1a;WINR-->CMD--->node --version 出现下图即可 2. 安装UI5 CLI (为了后面我们方便使用UI5 的命令…

向ChatGPT提特殊问题,可提取原始训练数据!

随着ChatGPT等模型的参数越来越大&#xff0c;预训练数据也呈指数级增长。谷歌DeepMind、华盛顿大学、康奈尔大学等研究人员发现,无论是开源还是闭源模型&#xff0c;在训练过程中皆能记住一定数量的原始训练数据样本。 如果使用特定的恶意攻击&#xff0c;便能轻松地从模型中…

python pip 相关缓存清理(windows+linux)

pip会大量缓存&#xff0c;如果全部堆在系统盘&#xff0c;会造成别的无法使用 windows和linux通用 一、linux linux是在命令行操作 1.查看缓存位置 pip cache dir我这里默认是在/root/.cache/pip 2.查看大小 du -sh /root/.cache/pip结果如下&#xff1a; 3.清理&#…

Redis的四种部署模式:原理、优缺点及应用场景

Redis是一款高性能的开源NoSQL数据库&#xff0c;它支持多种数据结构&#xff0c;如字符串、列表、集合、散列、有序集合等。Redis的主要特点是将所有数据存储在内存中&#xff0c;实现了极高的读写速度&#xff0c;同时也提供了持久化机制&#xff0c;保证了数据的安全性和一致…

深入理解 Go Channel:解密并发编程中的通信机制

一、Channel管道 1、Channel说明 共享内存交互数据弊端 单纯地将函数并发执行是没有意义的。函数与函数间需要交互数据才能体现编发执行函数的意义虽然可以使用共享内存进行数据交换&#xff0c;但是共享内存在不同的goroutine中容易发送静态问题为了保证数据交换的正确性&am…

Windows的C盘爆掉了怎么办?

本文参考&#xff1a; C盘太满怎么办&#xff1f;亲测8种好用方法&#xff01; 如果C盘的分区爆掉了&#xff0c;变红色了&#xff0c;是时候该处理这个问题了&#xff0c;解决你的C盘焦虑&#xff01; 第一招&#xff1a;删除C盘文件 首先你会想到清理C盘里面的文件&#x…

数据结构之----数组、链表、列表

数据结构之----数组、链表、列表 什么是数组&#xff1f; 数组是一种线性数据结构&#xff0c;它将相同类型的元素存储在连续的内存空间中。 我们将元素在数组中的位置称为该元素的索引。 数组常用操作 1. 初始化数组 我们可以根据需求选用数组的两种初始化方式&#xff…

机器视觉系统选型-同轴光源分类及应用场景

同轴光源 从与相机同轴的方向均匀照射漫射光 Mark点定位条码识别二维码识别反光物体表面缺陷检测 高亮同轴光源 照射光线与水平方向成低角度夹角Mark点定位反光件表面凹坑、损伤、缺陷印刷电路板二维码识别 平行同轴光源 从与相机同轴方向照射平行度高 的平行光尺寸测量玻璃检…

【图像处理】图像骨架化提取c++实现

以下代码是对图像进行骨架提取的函数&#xff1a; void thinImage(cv::Mat& src, int maxIterations) {assert(src.type() CV_8UC1);cv::Mat dst(src.size(), src.type());int width src.cols;int height src.rows;for (int i 0; i < height; i){uchar* ptr src.p…

团队git操作流程

项目的开发要求 项目组厉员每天代码提交不少于20次企业项目开发代码的每天的提交一般提交3-5次代码仓库的管理 git的基础操作流程 命令模式 git push插件模式 vscode git graphGUI软件管理模式 sourcetree git在项目团队化开发中的应用 master(一般是不动的)dev (主要是拿…

2. 如何通过公网IP端口映射访问到设备的vmware虚拟机的ubuntu服务器

文章目录 1. 主机设备是Windows 11系统2. 安装vmware虚拟机3. 创建ubuntu虚拟机&#xff08;据说CentOS 7 明年就不维护了&#xff0c;就不用这个版本的linux了&#xff09;4. 安装nginx服务:默认端口805. 安装ssh服务:默认端口226. 设置主机 -> ubuntu的端口映射7. 设置路由…

【Amis Low Code 结合FastAPI进行前端框架开发】

官方文档 封装思想 直接复制官网json数据即可开发每个json中的接口由fastapi 转发&#xff08;透传&#xff09;使其开发模式与前端思维一致 基础组件 from amis import Page, Service, App from pydantic import BaseModel, Field from fastapi import FastAPI, Request, …

vue:this.reload()跟this.$router.replace的区别

this.reload() 页面是否会执行 created&#xff0c; 它跟 this.$router.replace的区别 都是页面初始化&#xff0c; url地址中没有rowId&#xff0c;reload可以使用&#xff0c;最终也是对路由进行刷新&#xff0c; 一个祖先组件通过设置provide/inject向其所有子孙后代注入一个…

c++学习之智能指针

前言&#xff1a;在此之前我们已经学习到了异常的使用&#xff0c;虽然异常在大部分情况都还可以&#xff0c;但也存在太多缺陷&#xff0c;对于异常的问题&#xff0c;入内存泄漏&#xff0c;在复杂的场景下使用起来也是非常麻烦。为了更好的解决这些问题&#xff0c;c11中引入…

Vue中比较两个JSON对象的差异

要在Vue.js中实现JSON数据的对比差异功能&#xff0c;你可以使用一些库来简化任务&#xff0c;比如diff-match-patch。以下是一个简单的例子&#xff0c;演示如何使用deep-diff库在Vue.js中比较两个JSON对象的差异&#xff1a; 首先&#xff0c;确保你的项目中已经安装了diff-m…

C语言—每日选择题—Day45

第一题 1. 以下选项中&#xff0c;对基本类型相同的指针变量不能进行运算的运算符是&#xff08;&#xff09; A&#xff1a; B&#xff1a;- C&#xff1a; D&#xff1a; 答案及解析 A A&#xff1a;错误&#xff0c;指针不可以相加&#xff0c;因为指针相加可能发生越界&…