HTTP数据请求

1 概述
日常生活中我们使用应用程序看新闻、发送消息等,都需要连接到互联网,从服务端获取数据。例如,新闻应用可以从新闻服务器中获取最新的热点新闻,从而给用户打造更加丰富、更加实用的体验。

那么要实现这样一种能实时从服务端获取数据的场景,就依赖于HTTP数据请求。

2 什么是HTTP

HTTP即超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。
在这里插入图片描述

HTTP的工作原理正如上图所示,客户端向服务端发出一条HTTP数据请求,服务端接收请求后向客户端返回一些数据,然后客户端再对这些数据进行解析和处理。
3 如何发起HTTP请求
HTTP数据请求功能主要由http模块提供,包括发起请求、中断请求、订阅/取消订阅HTTP Response Header 事件等。
在进行网络请求前,您需要在module.json5文件中申请网络访问权限。

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

应用访问网络需要申请ohos.permission.INTERNET权限,因为HarmonyOS提供了一种访问控制机制即应用权限,用来保证这些数据或功能不会被不当或恶意使用。关于应用权限的的详细信息开发者可以参考:访问控制。
您可以按照以下步骤完成HTTP数据请求:

  1. 导入http模块。import http from ‘@ohos.net.http’;
  2. 创建httpRequest对象。使用createHttp()创建一个httpRequest对象,里面包括常用的一些网络请求方法,比如request、destroy、on(‘headerReceive’)等。let httpRequest = http.createHttp();需要注意的是每一个httpRequest对象对应一个http请求任务,不可复用。
  3. 订阅请求头(可选)。用于订阅http响应头,此接口会比request请求先返回,可以根据业务需要订阅此消息。
  4. 发起http请求。http模块支持常用的POST和GET等方法,封装在RequestMethod中。调用request方法发起网络请求,需要传入两个参数。第一个是请求的url地址,第二个是可选参数,类型为HttpRequestOptions,用于定义可选参数的类型和取值范围,包含请求方式、连接超时时间、请求头字段等。使用Get请求,参数内容需要拼接到URL中进行发送,如下示例中在url后面拼接了两个自定义参数,分别命名为param1和param2,值分别为value1和value2:
  5. 处理响应结果。data为网络请求返回的结果,err为请求异常时返回的结果。data的类型为HttpResponse。
httpRequest.on('headersReceive', (header) => {
  console.info('header: ' + JSON.stringify(header));
});
let url= "https://EXAMPLE_URL?param1=v1&param2=v2";
let promise = httpRequest.request(
  // 请求url地址
  url,
  {
    // 请求方式
    method: http.RequestMethod.GET,
    // 可选,默认为60s
    connectTimeout: 60000,
    // 可选,默认为60s
    readTimeout: 60000,
    // 开发者根据自身业务需要添加header字段
    header: {
      'Content-Type': 'application/json'
    }
  });

POST请求参数需要添加到extraData里面,如下示例中在extraData里面定义添加了两个自定义参数param1和param2,值分别为value1和value2:

let url = "https://EXAMPLE_URL";
let promise = httpRequest.request(
  // 请求url地址
  url,
  {
    // 请求方式
    method: http.RequestMethod.POST,
    // 请求的额外数据。
    extraData: {
      "param1": "value1",
      "param2": "value2",
    },
    // 可选,默认为60s
    connectTimeout: 60000,
    // 可选,默认为60s
    readTimeout: 60000,
    // 开发者根据自身业务需要添加header字段
    header: {
      'Content-Type': 'application/json'
    }
  });
promise.then((data) => { 
  if (data.responseCode === http.ResponseCode.OK) {
    console.info('Result:' + data.result);
    console.info('code:' + data.responseCode);
  }
}).catch((err) => {
  console.info('error:' + JSON.stringify(err));
});

其中data.responseCode为http请求返回的状态码,如果状态码为http.ResponseCode.OK(即200),则表示请求成功,更多状态码可以在ResponseCode中查看。data.result为服务器返回的业务数据,开发者可以根据自身业务场景解析此数据。
在这里插入图片描述

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于HTTP请求丢失部分数据的问题,有几种可能的原因和解决方法: 1. 网络连接问题:首先,确保你的网络连接稳定。如果你的网络连接不稳定或者存在中断,可能会导致HTTP请求中的数据丢失。你可以尝试重新连接网络或者重新启动网络设备来解决问题。 2. 服务器问题:如果HTTP请求中的数据在传输过程中丢失,可能是由于服务器端的问题。你可以检查服务器的日志或者联系服务器管理员,了解是否有任何错误或异常情况发生。他们可能需要调整服务器配置或进行故障排除来解决问题。 3. 请求超时:如果HTTP请求的响应时间超过服务器设置的超时时间,服务器可能会中断连接并丢失部分数据。你可以尝试增加请求的超时时间,以便服务器有足够的时间处理请求并返回完整的数据。 4. 数据包丢失:在传输过程中,数据包可能会丢失或损坏。这可能是由于网络拥塞、不稳定的链路或其他原因引起的。你可以尝试使用可靠的传输协议,如TCP,来确保数据的可靠传输。另外,使用HTTPS协议可以提供数据的加密和完整性校验,以减少数据丢失的风险。 5. 请求错误:有时候,HTTP请求中的数据丢失是由于请求本身的问题引起的。你可以检查请求的参数、头部信息等,确保它们正确无误。另外,确保你的代码没有任何bug或逻辑错误,导致数据丢失。 如果你遇到了HTTP请求丢失部分数据的问题,可以根据以上的解决方法逐一排查,找到并解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值