HarmonyOS鸿蒙ArkTS/ArkUI项目,封装http网络请求,封装公共API以及调用请求的过程实现。

我们在日常当中开发鸿蒙项目的时候,调用@ohos.net.http (数据请求)方法去请求接口,整个组件的语法糖会很繁琐,我们对@ohos.net.http (数据请求)方法进行一下二次公共API接口封装http网络请求,实现接口的简单方便快捷的调用。

一、封装api.ets,将常用的post、get、put、delete请求进行封装。

// api.ets文件
const BASE_URL: string = 'http://120.46.58.55';//这里写接口地址
import http from '@ohos.net.http';

export function httpRequestDel(url: string) {
  url = BASE_URL+url
  let httpRequest = http.createHttp();
  var header = {
    'Content-Type': 'application/json',
  }
  let responseResult = httpRequest.request(url, {
    method: http.RequestMethod.DELETE,
    header: header
  });
  return responseResult
}


export function httpRequestPut(url: string, params: any) {
  url = BASE_URL+url
  let httpRequest = http.createHttp();
  var header = {
    'Content-Type': 'application/json',
  }
  let responseResult = httpRequest.request(url, {
    method: http.RequestMethod.PUT,
    extraData: params,
    header: header
  });
  return responseResult
}


export function httpRequestPost(url: string, params: any) {
  url = BASE_URL+url
  let httpRequest = http.createHttp();
  var header = {
    'Accept': '*/*',
    "Content-Type": "application/x-www-form-urlencoded;charset=UTF-8",
  };
  let responseResult=httpRequest.request(url, {
    method: http.RequestMethod.POST,
    extraData: params,
    header: header
  });
  return responseResult
}

export function httpRequestGet(url: string,query: any) {
  url = BASE_URL+url+query
  let httpRequest = http.createHttp();
  var header = {
    'Content-Type': 'application/json',
  }
  let responseResult = httpRequest.request(url, {
    method: http.RequestMethod.GET,
    header: header
  });
  return responseResult
}

二、请求调用封装的公共接口api.ets

// @ts-nocheck
import {httpRequestPost} from './api/api';
import Url from '@ohos.url'

@Entry
@Component
struct Login {
  @State username:string='';
  @State password:string='';

  build() {
    Column() {
      // header();
      TextInput({ placeholder: '请输入账号',text:this.username }).margin({ top: 20 })
        .onChange((value:string)=>{
          this.username=value;
        })
      TextInput({ placeholder: '请输入密码',text:this.password }).type(InputType.Password).margin({ top: 20 })
        .onChange((value:string)=>{
          this.password=value;
        })
      Button('登录')
        .width(200)
        .margin({ top: 20 })
        .backgroundColor('#ff832317')
        .onClick(()=>{
          //参数处理
          let body: Map<string, any> = new Map<string, any>();
          body.set("username", this.username)
          body.set("password", this.password)
          let param = new Url.URLParams(Object.fromEntries(body)).toString();
          //新封装方法测试
          let responseResult=httpRequestPost('/api/login3',param)
          responseResult.then((res)=>{
            if (res.responseCode=200) {
              let data:JSON=JSON.parse(res.result);
              console.info(res.responseCode);
              console.info(data);
            };
          }).catch((err)=>{
            console.log(err);
          });
        })
    }.padding(20)
  }
}
export default Login

本文原创,原创不易,如需转载,请联系作者授权。

  • 15
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
根据引用内容,在使用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 ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值