XML API调用不适用于ionic3中的cordova-plugin-advanced-http最新版本

时间:2018-10-08 05:11:48

标签: ios xml ionic3 cordova-plugin-advanced-http

我正在使用cordova-plugin-advanced-http插件进行API调用,并且所有启用JSON的API都可以正常工作,但是我有一个XML嵌入式API在Postman中可以正常工作,但是我从ionic调用它的参数不在服务器端。

以下是我的XML API代码:

类型1:

let headers = {
          "Content-type": 'text/xml; charset=utf-8',
          "Authorization": token,
        };

    let xmlBody =
      '<ServiceRequest>' +
      '<CaseNumber>' + caseNumber +
      '</CaseNumber>' +
      '</ServiceRequest>'

    this.httpPlugin.setDataSerializer('utf8');

    this.httpPlugin.post('https://test.com/Service', xmlBody, headers).then((response) => {
      console.log("XML Response : ", JSON.stringify(response.data));
      xml2js.parseString(response.data, function (err, result) {
        console.log("XML parser success:", result);
        console.log("XML parser error:", err);
        if (result) {
          resolve(result);
        } else {
          reject(err);
        }

      });
    }).catch(error => {
      if (error.status == 403) {
        console.log("Token expired : " + JSON.stringify(error));
      } else {
        console.log("Error : " + error.error);
        console.log("Error " + JSON.stringify(error));
        reject(error);
      }
    });

类型2:

    let xmlBody = '<ServiceRequest>' +
      '<CaseNumber>' + caseNumber +
      '</CaseNumber>' +
      '</ServiceRequest>';

    console.log("XML Body", xmlBody)

    // this.httpPlugin.setRequestTimeout(60);
    this.httpPlugin.setDataSerializer('utf8');

    this.httpPlugin.setHeader('*', 'authorization', token);
    this.httpPlugin.setHeader('*', 'Content-Type', "application/x-www-form-urlencoded");

    this.httpPlugin.post('https://test.com/Service', xmlBody, {}).then((response) => {
      console.log("XML Response : ", JSON.stringify(response.data));
      xml2js.parseString(response.data, function (err, result) {
        console.log("XML parser success:", result);
        console.log("XML parser error:", err);
        if (result) {
          resolve(result);
        } else {
          reject(err);
        }

      });

    }).catch(error => {
      if (error.status == 403) {
        console.log("Token expired : " + JSON.stringify(error));
      } else {
        console.log("Error : " + error.error);
        console.log("Error " + JSON.stringify(error));
        reject(error);
      }

    });

一直以来,它都会从服务器抛出错误,并且通过相同的请求,我能够以邮递员以及本机iOS代码获取数据。

我在GitHub上提到了this问题,但仍然没有成功。

虽然无法在服务器上获取数据,但我仍然缺少一些东西。

帮我解决这个问题。

1 个答案:

答案 0 :(得分:0)

在这个问题上苦苦挣扎之后,我找到了清理请求cookie的解决方案。

在http高级插件中,有一种清除我的cookie的方法。

  

clearCookies()

     

清除所有cookie。

在调用任何API之前使用此方法。

因此它将清除所有cookie,并且我的与旧cookie有关的问题将通过这种方式解决。

constructor(
    public storage: Storage,
    public httpPlugin: HTTP,
    private platform: Platform
  ) {
    // enable SSL pinning
    httpPlugin.setSSLCertMode("pinned");
    //Clear old cookies
    httpPlugin.clearCookies();
  }

以上代码解决了我的问题。

感谢大家的快速指导和建议。

对此发表评论,如果这不是清除我的旧请求数据的正确方法。