没有请求数据的Angularjs触发请求

时间:2015-12-23 11:49:45

标签: javascript angularjs http angular-promise

首先,如果问题重复,我会道歉。

我正在使用$ 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请求两次同一个请求,一次没有数据,另一次请求数据。

请帮助解决这个奇怪的问题。请查看这些图像,这些图像显示两个不同的请求,一个是数据,另一个没有数据。

First Request enter image description here

1 个答案:

答案 0 :(得分:0)

首先,你得到两个请求,因为其中一个是OPTIONS调用,一个是实际的POST调用。这是正常行为,无需担心。

您正在发出的第二个请求是GET请求,该请求不能包含任何POST数据。这不受HTTP支持。 因此,根据后端的期望,您可以将该请求转换为POST请求,也可以将数据添加为GET参数,如下所述:in the Angular docs