source

AngularJs $http.post()이 데이터를 전송하지 않음

gigabyte 2023. 3. 15. 19:41
반응형

AngularJs $http.post()이 데이터를 전송하지 않음

왜 다음 명세서가 지정된 URL에 포스트 데이터를 보내지 않는지 알 수 있을까요?URL이 호출되지만 $_POST를 인쇄하면 서버에서 빈 배열이 나타납니다.데이터에 추가하기 전에 콘솔에서 메시지를 인쇄하면 올바른 내용이 표시됩니다.

$http.post('request-url',  { 'message' : message });

또한 데이터를 문자열로 사용해 보았습니다(동일한 결과).

$http.post('request-url',  "message=" + message);

다음과 같은 형식으로 사용하면 동작하고 있는 것 같습니다.

$http({
    method: 'POST',
    url: 'request-url',
    data: "message=" + message,
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
});

하지만 $http.post()을 사용하는 방법이 있습니까?또, 헤더를 넣으려면 반드시 헤더를 포함해야 합니까?위의 콘텐츠 타입은 보낸 데이터의 포맷을 지정하는 것이라고 생각합니다만, javascript 오브젝트로 보내도 될까요?

asp.net MVC에서도 같은 문제가 발생하여 여기에서 해결 방법을 찾았습니다.

Angular에 새로 온 사람들 사이에 혼란이 많다.JS는 그 이유를$http functions(서비스 속기 함수$http.post()등)는 jQuery와 스왑할 수 없는 것 같습니다.(jQuery.post()의 개요)

차이점jQuery와 Angular가 어떻게JS는 데이터를 직렬화하여 전송합니다.기본적으로 문제는 선택한 서버 언어가 Angular를 인식하지 못하는 데 있습니다.JS의 전송은 기본적으로...기본적으로 jQuery는 다음을 사용하여 데이터를 전송합니다.

Content-Type: x-www-form-urlencoded

그리고 친숙한 사람foo=bar&baz=moe시리얼화

단, AngularJS는 다음과 같은 방법으로 데이터를 전송합니다.

Content-Type: application/json 

★★★★★★★★★★★★★★★★★」{ "foo": "bar", "baz": "moe" }

불행히도 일부 웹 서버 언어(특히 PHP)는 기본적으로 직렬화를 해제하지 않습니다.

마법처럼 작동한다.

코드

// Your app's root module...
angular.module('MyModule', [], function($httpProvider) {
  // Use x-www-form-urlencoded Content-Type
  $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8';
 
  /**
   * The workhorse; converts an object to x-www-form-urlencoded serialization.
   * @param {Object} obj
   * @return {String}
   */ 
  var param = function(obj) {
    var query = '', name, value, fullSubName, subName, subValue, innerObj, i;
      
    for(name in obj) {
      value = obj[name];
        
      if(value instanceof Array) {
        for(i=0; i<value.length; ++i) {
          subValue = value[i];
          fullSubName = name + '[' + i + ']';
          innerObj = {};
          innerObj[fullSubName] = subValue;
          query += param(innerObj) + '&';
        }
      }
      else if(value instanceof Object) {
        for(subName in value) {
          subValue = value[subName];
          fullSubName = name + '[' + subName + ']';
          innerObj = {};
          innerObj[fullSubName] = subValue;
          query += param(innerObj) + '&';
        }
      }
      else if(value !== undefined && value !== null)
        query += encodeURIComponent(name) + '=' + encodeURIComponent(value) + '&';
    }
      
    return query.length ? query.substr(0, query.length - 1) : query;
  };
 
  // Override $http service's default transformRequest
  $httpProvider.defaults.transformRequest = [function(data) {
    return angular.isObject(data) && String(data) !== '[object File]' ? param(data) : data;
  }];
});

위의 내용은 명확하지 않지만 PHP로 요청을 수신하는 경우 다음을 사용할 수 있습니다.

$params = json_decode(file_get_contents('php://input'),true);

Angular에서 PHP의 배열에 액세스하려면JS POST

다음과 같이 기본 "Content-Type"을 설정할 수 있습니다.

$http.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded";

『 』에 data★★★★

$http.우편과 $190.put 메서드는 임의의 JavaScript 객체(또는 문자열) 값을 데이터 파라미터로 받아들입니다.데이터가 JavaScript 개체인 경우 기본적으로 JSON 문자열로 변환됩니다.

이 변형을 사용해 보세요.

function sendData($scope) {
    $http({
        url: 'request-url',
        method: "POST",
        data: { 'message' : message }
    })
    .then(function(response) {
            // success
    }, 
    function(response) { // optional
            // failed
    });
}

저도 같은 문제가 있었습니다만, 이것도 도움이 될 수 있을까요?https://stackoverflow.com/a/11443066

var xsrf = $.param({fkey: "key"});
$http({
    method: 'POST',
    url: url,
    data: xsrf,
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
})

안부 전해요,

오브젝트를 Post Param으로 변환하는 기능을 사용하고 싶다.

myobject = {'one':'1','two':'2','three':'3'}

Object.toparams = function ObjecttoParams(obj) {
    var p = [];
    for (var key in obj) {
        p.push(key + '=' + encodeURIComponent(obj[key]));
    }
    return p.join('&');
};

$http({
    method: 'POST',
    url: url,
    data: Object.toparams(myobject),
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
})

문제는 $httpParamSerializer를 사용하여 드디어 각도 1.4로 해결되었습니다.JQLike

https://github.com/angular/angular.js/issues/6039 를 참조해 주세요.

.controller('myCtrl', function($http, $httpParamSerializerJQLike) {
$http({
  method: 'POST',
  url: baseUrl,
  data: $httpParamSerializerJQLike({
    "user":{
      "email":"wahxxx@gmail.com",
      "password":"123456"
    }
  }),
  headers:
    'Content-Type': 'application/x-www-form-urlencoded'
})})

각도와 함께 jQuery param을 사용합니다.JS 포스트 리크레스트예를 들어... 각도 만들기JS 어플리케이션모듈, 여기서myapp되어 있습니다.ng-appHTML " " " " " " " 。

var app = angular.module('myapp', []);

로그인 컨트롤러와 POST 이메일 및 비밀번호를 만듭니다.

app.controller('LoginController', ['$scope', '$http', function ($scope, $http) {
    // default post header
    $http.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8';
    // send login data
    $http({
        method: 'POST',
        url: 'https://example.com/user/login',
        data: $.param({
            email: $scope.email,
            password: $scope.password
        }),
        headers: {'Content-Type': 'application/x-www-form-urlencoded'}
    }).success(function (data, status, headers, config) {
        // handle success things
    }).error(function (data, status, headers, config) {
        // handle error things
    });
}]);

.것을)))))):::::::::)param를 모두 .Query(쿼리) jQuery(jQuery) Angular(각)입니다.JS에 관한 것입니다.여기 스크린샷이 있습니다.

여기에 이미지 설명 입력

이게 도움이 됐으면 좋겠네요.감사합니다!

나도 Angular한테 같은 문제가 있었어JS 및 Node.js + Express 4 + 라우터

라우터는 본문에서 POST 요구로부터의 데이터를 기대하고 있습니다.Angular Docs의 예를 따르면 이 본문은 항상 비어 있었습니다.

표기법 1

$http.post('/someUrl', {msg:'hello word!'})

하지만 만약 내가 그것을 데이터에 사용한다면

표기법 2

$http({
       withCredentials: false,
       method: 'post',
       url: yourUrl,
       headers: {'Content-Type': 'application/x-www-form-urlencoded'},
       data: postData
 });

편집 1:

그렇지 않으면 node.js 라우터는 표기법1을 사용하면 req.body 내의 데이터를 상정합니다.

req.body.msg

JSON 페이로드로서도 정보가 송신됩니다.이는 json에 어레이가 있고 x-www-form-urlencoded가 있는 경우에 더 좋습니다.

효과가 있었어요도움이 됐으면 좋겠다.

JQuery와는 달리 POST 데이터를 클라이언트에서 서버로 전송하기 위해 Angular는 JSON 형식을 사용합니다(JQuery와 Angular는 데이터 임풋에 JSON을 사용하지만, JQuery는 x-ww-form-urlencoded를 적용할 가능성이 있습니다).따라서 문제의 두 부분이 있습니다.js 클라이언트 부분과 서버 부분입니다.필요한 것은 다음과 같습니다.

  1. 각도 클라이언트 부품을 다음과 같이 배치합니다.

    $http({
    method: 'POST',
    url: 'request-url',
    data: {'message': 'Hello world'}
    });
    

그리고.

  1. 클라이언트로부터 데이터를 수신하기 위해서 서버 부분에 기입합니다(php의 경우).

            $data               = file_get_contents("php://input");
            $dataJsonDecode     = json_decode($data);
            $message            = $dataJsonDecode->message;
            echo $message;     //'Hello world'
    

주의: $_POST는 작동하지 않습니다!

그 해결책은 나에게도, 그리고 당신에게도 효과가 있습니다.

@felipe-mioso의 답변을 기반으로 하려면:

  1. Angular로 다운로드여기서부터 JS 모듈,
  2. 인스톨
  3. 응용 프로그램에 추가합니다.

    var app = angular.module('my_app', [ ... , 'httpPostFix']);
    

methode를 사용하여 Post $http angularjs를 바꿔야 .

data: "message=" + message, 를 사용하여, 를 참조해 주세요.data: $.param({message:message})

평판은 없지만 Don F의 답변에 대한 답변/추가:

$params = json_decode(file_get_contents('php://input'));

" " " " " " " "true 때 요.json_decode관련지어져 있는 어레이를 올바르게 반환하기 위한 함수:

$params = json_decode(file_get_contents('php://input'), true);

각진

  var payload = $.param({ jobId: 2 });

                this.$http({
                    method: 'POST',
                    url: 'web/api/ResourceAction/processfile',
                    data: payload,
                    headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
                });

WebAPI 2

public class AcceptJobParams
        {
            public int jobId { get; set; }
        }

        public IHttpActionResult ProcessFile([FromBody]AcceptJobParams thing)
        {
            // do something with fileName parameter

            return Ok();
        }

이 코드로 문제가 해결되었습니다.애플리케이션 레벨의 솔루션입니다.

moduleName.config(['$httpProvider',
  function($httpProvider) {
    $httpProvider.defaults.transformRequest.push(function(data) {
        var requestStr;
        if (data) {
            data = JSON.parse(data);
            for (var key in data) {
                if (requestStr) {
                    requestStr += "&" + key + "=" + data[key];
                } else {
                    requestStr = key + "=" + data[key];
                }
            }
        }
        return requestStr;
    });
    $httpProvider.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded";
  }
]);

js 파일에 다음 내용을 추가합니다.

$http.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded";

서버 파일에 다음 항목을 추가합니다.

$params = json_decode(file_get_contents('php://input'), true);

그러면 되겠군요.

저도 비슷한 문제에 직면해서 이런 일을 하다가 잘 안 됐어요.스프링 컨트롤러에서 데이터 파라미터를 읽을 수 없었습니다.

var paramsVal={data:'"id":"1"'};
  $http.post("Request URL",  {params: paramsVal});  

하지만 이 포럼과 API Doc을 읽으면서, 저는 팔로잉을 시도했고, 그것은 저에게 효과가 있었습니다.비슷한 문제가 있는 사람도 있다면 아래 방법으로 시도해 보세요.

$http({
      method: 'POST',
      url: "Request URL",           
      params: paramsVal,
      headers: {'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'}
            });

param config 의 기능에 대해서는, https://docs.angularjs.org/api/ng/service/$http#post 를 참조해 주세요.{data:'id":"1"} – URL?data="id:1"로 변환되는 문자열 또는 개체의 맵

이지만, 은 " 요청을 할 때 "get" 요청을 할 때 이라고 생각합니다.$httpParamSerializer를 전혀할 수 Jquery를 .$http.post(url,$httpParamSerializer({param:val}))

app.controller('ctrl',function($scope,$http,$httpParamSerializer){
    $http.post(url,$httpParamSerializer({param:val,secondParam:secondVal}));
}

내 경우 다음과 같이 문제를 해결합니다.

var deferred = $q.defer();

$http({
    method: 'POST',
    url: 'myUri', 
    data: $.param({ param1: 'blablabla', param2: JSON.stringify(objJSON) }),
    headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
}).then(
    function(res) {
        console.log('succes !', res.data);
        deferred.resolve(res.data);
    },
    function(err) {
        console.log('error...', err);
        deferred.resolve(err);
    }
);
return deferred.promise;

JSON 개체를 포함하는 각 파라미터에 대해 JSON.stringify를 사용하고 "$param" :-)를 사용하여 데이터 개체를 빌드해야 합니다.

NB : "objJSON"은 배열, 정수, 문자열 및 html 콘텐츠를 포함하는 JSON 개체입니다.그의 총 사이즈는 3500자 이상이다.

대답을 받아들인 거 알아하지만, 만약 어떤 이유로든 그 답이 그들에게 맞지 않는다면, 팔로잉은 미래의 독자들에게 도움이 될 것이다.

Angular 와 jQuery angulareryAjax 。$httpprovider다른 했습니다. 코드 .$this->input->is_ajax_request()함수는 항상 실패(다른 프로그래머에 의해 작성되어 글로벌하게 사용되었기 때문에 변경할 수 없음)하여 이것이 실제 Ajax 요청이 아니라고 말합니다.

그것을 해결하기 위해 나는 약속을 미루었다.Firefox와 ie9에서 테스트했는데 작동했어요.

각도 코드 외부에 다음과 같은 함수가 정의되어 있습니다.이 함수는 정기적인 jquery ajax 호출을 하고 지연/약속(아직 학습 중입니다) 개체를 반환합니다.

function getjQueryAjax(url, obj){
    return $.ajax({
        type: 'post',
        url: url,
        cache: true,
        data: obj
    });
}

그럼 다음 코드를 사용하여 각도 코드라고 합니다.★★★★★★★★의 갱신이 필요하므로 주의해 .$scope에 의한 " " "$scope.$apply().

    var data = {
        media: "video",
        scope: "movies"
    };
    var rPromise = getjQueryAjax("myController/getMeTypes" , data);
    rPromise.success(function(response){
        console.log(response);
        $scope.$apply(function(){
            $scope.testData = JSON.parse(response);
            console.log($scope.testData);
        });
    }).error(function(){
        console.log("AJAX failed!");
    });

답은 수 을 사용할 수 jquery ajax를 할 수 있게 .$scope.

급행에서도 같은 문제가 있었습니다.해결하려면 http 요청을 보내기 전에 bodyparser를 사용하여 json 객체를 해석해야 합니다.

app.use(bodyParser.json());

angular js 이하의 코드가 동작하는 asp.net WCF Webservices를 사용하고 있습니다.

 $http({
        contentType: "application/json; charset=utf-8",//required
        method: "POST",
        url: '../../operation/Service.svc/user_forget',
        dataType: "json",//optional
        data:{ "uid_or_phone": $scope.forgettel, "user_email": $scope.forgetemail },
        async: "isAsync"//optional

       }).success( function (response) {

         $scope.userforgeterror = response.d;                    
       })

도움이 됐으면 좋겠다.

$http 사용 방법에 대한 완전한 코드 조각을 찾지 못했습니다.서버에 데이터를 송신하는 post 메서드와 이 경우 작동하지 않는 이유를 나타냅니다.

아래 코드 조각에 대한 설명...

  1. jQuery $.param 함수를 사용하여 JSON 데이터를 www 포스트 데이터로 시리얼화하고 있습니다.
  2. angular 요구와 함께 전달되는 설정 변수에서의 Content-Type 설정JS$http.www post 형식으로 데이터를 송신하는 것을 서버에 지시하는 post.

  3. $htttp.post 메서드에 주목하십시오.여기서 첫 번째 파라미터는 url, 두 번째 파라미터는 데이터(비교체) 및 세 번째 파라미터는 config로 전송합니다.

나머지 코드는 자체 인식됩니다.

$scope.SendData = function () {
           // use $.param jQuery function to serialize data from JSON 
            var data = $.param({
                fName: $scope.firstName,
                lName: $scope.lastName
            });

            var config = {
                headers : {
                    'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'
                }
            }

            $http.post('/ServerRequest/PostDataResponse', data, config)
            .success(function (data, status, headers, config) {
                $scope.PostDataResponse = data;
            })
            .error(function (data, status, header, config) {
                $scope.ResponseDetails = "Data: " + data +
                    "<hr />status: " + status +
                    "<hr />headers: " + header +
                    "<hr />config: " + config;
            });
        };

$http의 코드 예를 참조하십시오.post method는 이쪽입니다.

PHP를 사용하는 경우 Angular에서 PHP의 어레이에 쉽게 액세스할 수 있습니다.JS POST

$params = json_decode(file_get_contents('php://input'),true);

Angular > = 1.4를 사용하는 경우, Angular에서 제공하는 시리얼라이저를 사용하는 가장 깨끗한 솔루션은 다음과 같습니다.

angular.module('yourModule')
  .config(function ($httpProvider, $httpParamSerializerJQLikeProvider){
    $httpProvider.defaults.transformRequest.unshift($httpParamSerializerJQLikeProvider.$get());
    $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded; charset=utf-8';
});

그리고 앱 내 어디에서나 간단하게 이 작업을 수행할 수 있습니다.

$http({
  method: 'POST',
  url: '/requesturl',
  data: {
    param1: 'value1',
    param2: 'value2'
  }
});

데이터를 .param1=value1&param2=value2에 송신합니다./requesturlapplication/x-www-form-urlencoded; charset=utf-8Content-Type " ( " POST " ) 。

TL;DR

조사 중에 이 문제에 대한 해답은 여러 가지 맛이 있다는 것을 알게 되었습니다.어떤 것은 매우 복잡하고 커스텀 함수에 의존하며, 어떤 것은 jQuery에 의존하며, 어떤 것은 헤더를 설정하기만 하면 된다는 불완전한 것을 알 수 있었습니다.

「 」를 ,Content-Type로서 문자열을 하지 않는 한 .왜냐하면 스트링을 입력하지 않는 한data또는 수동으로 데이터 개체를 직렬화하면 기본적으로 모두 JSON으로 직렬화되며 엔드포인트에서 잘못 해석될 수 있습니다.

예를 들어 위의 예에서 올바른 시리얼라이저가 설정되어 있지 않은 경우 엔드포인트에는 다음과 같이 표시됩니다.

{"param1":"value1","param2":"value2"}

ASP와 같은 예기치 않은 파싱이 발생할 수 있습니다.을 NET으로 한다.null " " " " 가 붙은 파라미터명{"param1":"value1","param2":"value2"}로 해석하여 "Fiddler"로 지정합니다.{"param1":"value1","param2":"value2"}파라미터명으로 지정합니다.null그 가치로.

형식 OP가 Denison을 사용하는 입니다.$http.post한 것이 $httpj에 합니다.질문하다.

여기서 jQuery를 사용하면 복잡한 오브젝트가 올바르게 전달된다는 장점이 있습니다.데이터가 왜곡될 수 있는 URL 파라미터로 수동으로 변환되는 것에 반대합니다.

$http.post( 'request-url', jQuery.param( { 'message': message } ), {
    headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
});

보낼 데이터를 두 번째 매개 변수로 넣기만 하면 됩니다.

$http.post('request-url',  message);

다른 형태로는 다음과 같은 것이 있습니다.

$http.post('request-url',  { params: { paramName: value } });

「 」가 되어 것을 확인합니다.paramName는 호출하는 함수의 파라미터 이름과 정확히 일치합니다.

출처: Angular.JS 투고 바로가기 방식

이 문제가 발생했을 때, 투고하고 있던 파라미터는 단순한 오브젝트가 아닌 오브젝트 배열이었습니다.

방금 각도 1.2에서 1.3으로 업데이트 되었습니다.코드에서 문제가 발견되었습니다.자원을 변환하면 (내 생각에는) $promise가 동일한 객체를 다시 보유하기 때문에 무한 루프가 발생합니다.그게 누군가에게 도움이 될지도...

다음 방법으로 해결할 수 있습니다.

[...]
  /**
 * The workhorse; converts an object to x-www-form-urlencoded serialization.
 * @param {Object} obj
 * @return {String}
 */
var param = function (obj) {
var query = '', name, value, fullSubName, subName, subValue, innerObj, i;

angular.forEach(obj, function(value, name) {
+    if(name.indexOf("$promise") != -1) {
+        return;
+    }

    value = obj[name];
    if (value instanceof Array) {
        for (i = 0; i < value.length; ++i) {
[...]

한동안 승인된 답변의 코드(Felipe의 코드)를 사용했는데 잘 작동하고 있습니다(Felipe씨!).

그러나 최근 빈 객체 또는 어레이에 문제가 있음을 알게 되었습니다.예를 들어, 이 오브젝트를 송신하는 경우:

{
    A: 1,
    B: {
        a: [ ],
    },
    C: [ ],
    D: "2"
}

PHP는 B와 C를 전혀 인식하지 못하는 것 같습니다.다음과 같이 됩니다.

[
    "A" => "1",
    "B" => "2"
]

Chrome의 실제 요청을 보면 다음과 같습니다.

A: 1
:
D: 2

대체 코드 스니펫을 작성했습니다.사용 예에서는 잘 동작하는 것 같습니다만, 광범위하게 테스트한 적은 없기 때문에 주의해 주세요.

저는 강한 타이핑을 좋아하기 때문에 TypeScript를 사용했지만 순수 JS로 변환하는 것은 쉬울 것입니다.

angular.module("MyModule").config([ "$httpProvider", function($httpProvider: ng.IHttpProvider) {
    // Use x-www-form-urlencoded Content-Type
    $httpProvider.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded;charset=utf-8";

    function phpize(obj: Object | any[], depth: number = 1): string[] {
        var arr: string[] = [ ];
        angular.forEach(obj, (value: any, key: string) => {
            if (angular.isObject(value) || angular.isArray(value)) {
                var arrInner: string[] = phpize(value, depth + 1);
                var tmpKey: string;
                var encodedKey = encodeURIComponent(key);
                if (depth == 1) tmpKey = encodedKey;
                else tmpKey = `[${encodedKey}]`;
                if (arrInner.length == 0) {
                    arr.push(`${tmpKey}=`);
                }
                else {
                    arr = arr.concat(arrInner.map(inner => `${tmpKey}${inner}`));
                }
            }
            else {
                var encodedKey = encodeURIComponent(key);
                var encodedValue;
                if (angular.isUndefined(value) || value === null) encodedValue = "";
                else encodedValue = encodeURIComponent(value);

                if (depth == 1) {
                    arr.push(`${encodedKey}=${encodedValue}`);
                }
                else {
                    arr.push(`[${encodedKey}]=${encodedValue}`);
                }
            }
        });
        return arr;
    }

    // Override $http service's default transformRequest
    (<any>$httpProvider.defaults).transformRequest = [ function(data: any) {
        if (!angular.isObject(data) || data.toString() == "[object File]") return data;
        return phpize(data).join("&");
    } ];
} ]);

이것은 Felipe의 코드보다는 덜 효율적이지만 HTTP 요청 자체의 전체적인 오버헤드에 비해 즉시 이루어져야 하기 때문에 크게 문제가 되지 않는다고 생각합니다.

이제 PHP는 다음을 표시합니다.

[
    "A" => "1",
    "B" => [
        "a" => ""
    ],
    "C" => "",
    "D" => "2"
]

내가 아는 한, PHP가 B.a와 C가 빈 배열이라는 것을 인식하도록 하는 것은 불가능하지만, 적어도 키는 나타난다.이것은, 내부에 빈 구조라도 특정 구조에 의존하는 코드가 있는 경우에 중요하다.

또한 정의되지 않은 문자열과 null을 빈 문자열로 변환합니다.

이 문제는 아래 코드로 해결했습니다.

클라이언트측(JS):

     $http({
                url: me.serverPath,
                method: 'POST',
                data: data,
                headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
            }).
                success(function (serverData) {
                    console.log("ServerData:", serverData);
    ......

데이터가 오브젝트임을 알 수 있습니다.

서버(ASP).NET MVC):

[AllowCrossSiteJson]
        public string Api()
        {
            var data = JsonConvert.DeserializeObject<AgentRequest>(Request.Form[0]);
            if (data == null) return "Null Request";
            var bl = Page.Bl = new Core(this);

            return data.methodName;
        }

교차 도메인 요청에는 'AllowCrossSiteJsonAttribute'가 필요합니다.

public class AllowCrossSiteJsonAttribute : ActionFilterAttribute
    {
        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            filterContext.RequestContext.HttpContext.Response.AddHeader("Access-Control-Allow-Origin", "*");
            base.OnActionExecuting(filterContext);
        }
    }

이게 도움이 됐길 바라.

언급URL : https://stackoverflow.com/questions/19254029/angularjs-http-post-does-not-send-data

반응형