Asp. Net Web API, AngularJS POST-запрос - PullRequest
0 голосов
/ 25 марта 2020

Я хочу сделать почтовый запрос и передать строку в теле запроса. На данный момент имеется следующий контроллер asp. net и angularjs код. Проблема в том, что параметр "str" ​​равен нулю. Что я делаю не так?

Я пытался установить angularjs Content-Type как «application / json» и как «text / plain». Я пытался в asp. net с и без опции [FromBody]. Все основано на NET. Рамочная работа 4.6.2

[Route("sections/add")]
    [HttpPost]
    public HttpResponseMessage AddSection([FromBody]string str)
    {
        var response = this.Request.CreateResponse();

        str = str + " 1";

        response.Content = new StringContent(str, Encoding.UTF8, "application/json");
        return response;
    }

var calcsApp = angular.module('calcsCatApp', []);

calcsApp.controller('editController', ['$scope', '$rootScope', '$http', '$httpParamSerializerJQLike', function ($scope, $rootScope, $http, 
$httpParamSerializerJQLike) { 

    $scope.addSection = function (sectionToAdd) {
        let url = 'api/sections/add';
        let jData = { str: "Section1" };
        $http({
            method: 'POST',
            url: url,
            headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
            data: $httpParamSerializerJQLike(jData)
        })
        .then(function (response) {
            alert('response OK: ' + response.data);
        }, function (response) {
            alert('response error: ' + response.data);
        });
    };

}]);
<!DOCTYPE html>
<html ng-app="calcsCatApp">
<head>
    <meta charset="UTF-8">
</head>
<body>
<div ng-controller="editController">
<input type="button" value="+" ng-click="addSection()"/>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.7.5/angular.min.js">
</script>
</body>
</html>

1 Ответ

0 голосов
/ 26 марта 2020

Этот код работоспособен.

    [Route("sections/add")]
    [HttpPost]
    public HttpResponseMessage AddSection()
    {
        HttpResponseMessage response = this.Request.CreateResponse(HttpStatusCode.OK);
        string bodyString = Request.Content.ReadAsStringAsync().GetAwaiter().GetResult();
        response.Content = new StringContent(bodyString, Encoding.UTF8, "application/json");
        return response;
    }
...