当前位置: 首页 > article >正文

鸿蒙HarmonyOS之封装Http请求工具类

一、常量类 Constants.ets

//超时时间10秒
static readonly HTTP_READ_TIMEOUT: number = 10000;

//请求成功返回码
static readonly HTTP_CODE_200: number = 200;

//请求成功后data中的code值(根据实际情况定)
static readonly SERVER_CODE_SUCCESS: number = 0;

二、请求工具类HttpUtil.ets

import { http } from '@kit.NetworkKit';
import ResponseResult from '../bean/ResponseResult';
import Constants, { ContentType } from '../constants/Constants';

//Get请求
export function httpRequestGet(url: string) {
  return httpRequest(url, http.RequestMethod.GET);
}

//Post请求
export function httpRequestPost(url: string, requestData: Object) {
  return httpRequest(url, http.RequestMethod.POST, requestData);
}

//处理请求参数和请求结果
function httpRequest(url: string, method: http.RequestMethod, params?: Object): Promise<ResponseResult> {
  let httpRequest = http.createHttp();
  let responseResult = httpRequest.request(url, {
    method: method,
    readTimeout: Constants.HTTP_READ_TIMEOUT,
    header: {
      'Content-Type': ContentType.JSON,
    },
    connectTimeout: Constants.HTTP_READ_TIMEOUT,
    extraData: params
  });
  let serverData = new ResponseResult();
  return responseResult.then((value: http.HttpResponse) => {
    let result = `${value.result}`;
    let resultJson: ResponseResult = JSON.parse(result);
    if (value.responseCode === Constants.HTTP_CODE_200) {
      if (resultJson.code === Constants.SERVER_CODE_SUCCESS) {
        serverData.value = resultJson.value;
      }
      serverData.code = resultJson.code;
      serverData.msg = resultJson.msg;
    } else {
      serverData.code = resultJson.code;
      serverData.msg = resultJson.msg;
    }
    return serverData;
  }).catch(() => {
    return serverData;
  });
}

三、使用示例

1、可新建一个ets文件存放请求对象RequestBean和请求接收ResponseBean等对象

//DataPage类
export class DataPage<T> {

  pageIndex: number = 1; //页码
  pageSize: number = 10; //页面大小
  pageTotal: number = 1; //总页数
  amount: number = 0; //记录总数

  data: T[] = []; //本页数据
}

//请求Bean
export class ActivityRequest {

  token: string = "";
  clientType: string = "";
  page: number = 1;
}

//请求接收Bean
export class ActivityResponse {
  id: number = 0;
  mainActivityId: number = 0;
  name: string = "";
  .......
}

2、编写请求方法,传入请求参数,设置Url,处理请求结果等

 RequestData(page: number): Promise<DataPage<ActivityResponse>> {
    return new Promise((resolve: Function) => {
      let url = '请求Url.....';
      let requestData: ActivityRequest = new ActivityRequest();
      requestData.clientType = 'HarmonyOS';
      PreferencesUtil.getLoginToken().then((value) => {
        requestData.token = value;
        requestData.page = page;
        Logger.debug(this.TAG,'请求Url:'+ url)
        Logger.debug(this.TAG,'请求参数信息:'+ JSON.stringify(requestData))

		//这里调用HttpUtil工具类里面的Post请求方法
        httpRequestPost(url, requestData).then((data: ResponseResult) => {
          if (data && data.code === Constants.SERVER_CODE_SUCCESS) {
            resolve(data.value);
            Logger.debug(this.TAG,'请求成功!')
            //可以在此处处理请求结果,也可以在步骤3所示请求回调中处理请求的结果
          } else {
            Logger.debug(this.TAG,'请求失败!' + data.code + ": " + data.msg)
            resolve(null);
            if (data.code === -1) {
              showToast('请求异常')
            }else {
              showToast(data.msg)
            }
          }
        }).catch(() => {
          Logger.error(this.TAG,'请求异常!')
          showToast('网络请求异常!')
          resolve(null);
        });
      });

    });
  }

3、调用,返回请求成功后的数据结果,可进行后续处理

this.RequestData(page).then((result: DataPage<ActivityResponse>) => {
      if (result){
        Logger.debug(this.TAG,'页码pageIndex:'+ result.pageIndex + ' 每页数量pageSize:'+ result.pageSize + ' 总页数pageTotal:'+ result.pageTotal + '记录总数amount:' + result.amount)
        if(result.amount > 0) {
          Logger.debug(this.TAG,'数据:'+ JSON.stringify(this.liveDataList))
        }else{
          Logger.debug(this.TAG,'数据为空')
        }
      }
    });

四、完成,Nice!


http://www.kler.cn/a/326287.html

相关文章:

  • 蜀道山CTF<最高的山最长的河>出题记录
  • workerman的安装与使用
  • 后仿真中的GLS测试用例的选取规则
  • 抽象java入门1.5.3.1——类的进阶
  • 【AtCoder】Beginner Contest 380-C.Move Segment
  • MySQL中Flashback(闪回)技术
  • Spring Boot 进阶-第一个程序HelloWorld
  • C语言 | Leetcode C语言题解之第447题回旋镖的数量
  • knowLedge-Vue I18n 是 Vue.js 的国际化插件
  • SpringMVC源码-AbstractHandlerMethodMapping处理器映射器将@Controller修饰类方法存储到处理器映射器
  • 关于开发板与虚拟机网络不通问题排查
  • 在线点餐新体验:Spring Boot 点餐系统
  • excel不经过后台实现解析和预览(vue)
  • YOLOv8 Flask整合问题
  • Git 使用方法
  • c++泛型编程
  • 【hot100-java】【二叉树的层序遍历】
  • Excel:常用函数
  • vue中异步批量删除列表数据
  • 常用的MySQL日期、时间函数
  • 视频集成与融合项目中需要视频编码,但是分辨率不兼容怎么办?
  • 使用 C++ 实现卷积运算:从理论到实践的详细指南
  • Leetcode 739.42. 每日温度 接雨水 单调栈 C++实现
  • 局部整体(七)利用python绘制圆形嵌套图
  • 2024/9/29周报
  • SpringMVC5-域对象共享数据