HarmonyOS鸿蒙ArkTS,封装http网络请求

HarmonyOS鸿蒙ArkTS,封装http网络请求

前提:

要想使用http请求,系统必须要具备ohos.permission.INTERNET权限,在model.json5文件中的module模块下添加如下请求权限:

在module.json5文件中

配置

"requestPermissions": [
  {
    "name": "ohos.permission.INTERNET"
  }
]

定义响应格式 Response:

在文件中定义,文件目录自定义

export default class  Response {
  /**
   * 响应码
   */
  code:number
  /**
   * 响应消息
   */
  message:string
  /**
   * 响应数据
   */
  data:any
}

请求封装

//导入请求
import http from '@ohos.net.http';
//响应格式
import Response from '../inittype/public'

//导出去一个请求函数 使用axios风格请求数据、参数可自行增加
export function request(url:string,method: http.RequestMethod,data?:any): Promise<Response> {
  const BASE_URL =  "请求根地址"
  let httpRequest = http.createHttp();
  let responseResult = httpRequest.request( BASE_URL+ url,{
    method: method,
    //请求头设置
    header: {
      'Content-Type': 'application/json'
   },
    //携带额外参数
    extraData: JSON.stringify(data),
  });

  let response = new Response();
  // 处理数据,并返回
  return responseResult.then((result: http.HttpResponse) => {
    if (value.responseCode === 200) {
      let res: Response = JSON.parse(`${result.result}`);
      response.data = res.data;
      response.code = res.code;
      response.message = res.message;
    } else {
      response.message = '请求错误';
      response.code = 400;
    }
    return response;
  }).catch(() => {
    response.message = '请求错误';
    response.code = 400;
    return response;
  });
}

api封装

import http from '@ohos.net.http';
//导入封装好的请求
import { request } from '../utils/request'

/**
 * 获取信息
 */
 export default function getInfo(data) {
  return request(`/learun/adms/user/LoginByOaperson`,http.RequestMethod.POST,data)
}

使用:

至此整个请求封装结束

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用内容,在使用ArkTS开发HarmonyOS应用时,需要调用HTTP网络请求来获取数据并进行UI列表的刷新。根据官方文档提供的示例代码进行功能开发时,可能会遇到一些问题。其中一个常见的问题是,在封装HTTP请求的方法后,返回的数据总是为空,无法获取到调用接口的结果。 在解决这个问题之前,首先需要确保在配置文件module.json5中添加了ohos.permission.INTERNET权限,如引用所示。这是因为HTTP网络请求需要申请此权限才能正常工作。 另外,根据引用所示的异常描述,可能会遇到"org.springframework.http.converter.HttpMessageNotReadableException: Required request body is missing"异常。这个异常表示请求体缺失,可能是在封装HTTP请求方法时没有正确设置请求体。需要检查代码是否正确设置了请求体参数。 如果以上步骤都正确无误,但仍然无法获取到数据,可以进一步检查网络连接是否正常,以及接口是否正确返回数据。可以使用调试工具来查看请求和响应的具体信息,以便更好地定位问题。 总结起来,封装ArkTSHTTP请求时,需要确保配置文件中添加了ohos.permission.INTERNET权限,并检查代码是否正确设置了请求体参数。如果仍然无法获取到数据,可以进一步检查网络连接和接口返回数据的情况。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [【HarmonyOS】【ArkTS】如何使用HTTP网络请求获取动态数据刷新UI界面](https://blog.csdn.net/Mayism123/article/details/131082935)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Http请求异常Required request body is missing](https://blog.csdn.net/m0_37583655/article/details/130387221)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值