首先,如果问题重复,我会道歉。
我正在使用$ q服务发出ajax请求。
UtilityService.requestCall('/test/encrypt-data', {'json_string' : data_to_encrypt, 'encryption_key' : window.localStorage.getItem("Mi_Encryption_Key")})
.then(function(encrypt_response) {
var requestConoce = parseInt(window.localStorage.getItem("Mi_Cnonce")) + 1;
window.localStorage.setItem("Mi_Cnonce", requestConoce);
requestData['cnonce'] = requestConoce;
requestData['encrypted_data'] = encrypt_response.data;
return UtilityService.requestCall($scope.apiDetails.url, requestData, 'GET');
})
.then(function(api_response) {
var requestConoce = parseInt(window.localStorage.getItem("Mi_Cnonce")) + 1;
window.localStorage.setItem("Mi_Cnonce", requestConoce);
return UtilityService.requestCall('/test/decrypt-data', {'encrypted_string' : api_response.encrypted_data, 'encryption_key' : window.localStorage.getItem('Mi_Encryption_Key') });
})
.then(function(decrypt_response) {
$scope.serverResponse = JSON.stringify(decrypt_response);
return;
})
.catch(function(error) {
alert("Some Error");
})
MyApp.factory('UtilityService', ['$http', '$q', function($http, $q) {
return {
requestCall: function(requestUrl, requestData, methodType) {
var deferred = $q.defer();
var serverUrl = window.localStorage.getItem("Mi_Server_Url");
$http({
method: (methodType) ? methodType : "POST",
url: serverUrl + requestUrl,
data: requestData
})
.then(function(result) {
deferred.resolve(result.data);
},
function(error) {
deferred.reject(error);
});
return deferred.promise;
}
};}]);
我正在使用上面的代码发出请求。它适用于请求" / test / encrypt-data"
但是$scope.apiDetails.url
的请求无效。请求没有任何参数但是,我在requestData
发送所有必需的参数。
此代码适用于其他代码(即使我发送数据)但不适用于此请求。
似乎angularjs请求两次同一个请求,一次没有数据,另一次请求数据。
请帮助解决这个奇怪的问题。请查看这些图像,这些图像显示两个不同的请求,一个是数据,另一个没有数据。
答案 0 :(得分:0)
首先,你得到两个请求,因为其中一个是OPTIONS调用,一个是实际的POST调用。这是正常行为,无需担心。
您正在发出的第二个请求是GET请求,该请求不能包含任何POST数据。这不受HTTP支持。 因此,根据后端的期望,您可以将该请求转换为POST请求,也可以将数据添加为GET参数,如下所述:in the Angular docs