4.鸿蒙-如何发起一个http请求

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


    2.如何发起HTTP请求
        HTTP数据请求功能主要由http模块提供,包括发起请求、中断请求、订阅/取消订阅HTTP Response Header 事件等。

        在进行网络请求前,您需要在module.json5文件中申明网络访问权限。
        {
            "module" : {
                "requestPermissions":[
                   {
                     "name": "ohos.permission.INTERNET"
                   }
                ]
            }
        }

    a、导入http模块  import http from '@ohos.net.http';

    b、创建httpRequest对象。
    使用createHttp()创建一个httpRequest对象,里面包括常用的一些网络请求方法,比如request、destroy、on('headerReceive')等
    let httpRequest = http.createHttp();需要注意的是每一个httpRequest对象对应一个http请求任务,不可复用

    c、订阅请求头(可选)。
    用于订阅http响应头,此接口会比request请求先返回,可以根据业务需要订阅此消息。
    httpRequest.on('headersReceive', (header) => {
        console.info('header: ' + JSON.stringify(header));
    });

    d、发起http请求。
        http模块支持常用的POST和GET等方法,封装在RequestMethod中。调用request方法发起网络请求,需要传入两个参数。第一个是请求的url地址,第二个是可选参数,类型为HttpRequestOptions,用于定义可选参数的类型和取值范围,包含请求方式、连接超时时间、请求头字段等。

        1.使用Get请求,参数内容需要拼接到URL中进行发送,如下示例中在url后面拼接了两个自定义参数,分别命名为param1和param2,值分别为value1和value2:
        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'
            }
          });

        2.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'
                }
              });

    e.处理响应结果。
    data为网络请求返回的结果,err为请求异常时返回的结果。data的类型为HttpResponse。
        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为服务器返回的业务数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值