我正在使用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问题,但仍然没有成功。
虽然无法在服务器上获取数据,但我仍然缺少一些东西。
帮我解决这个问题。
答案 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();
}
以上代码解决了我的问题。
感谢大家的快速指导和建议。
对此发表评论,如果这不是清除我的旧请求数据的正确方法。