Публикация JQuery Datatable в ASP.NET Core вызывает ошибку 400 - PullRequest
0 голосов
/ 25 января 2019

Я установил таблицу DataTables в своем интерфейсе для обработки на стороне сервера, поскольку это большой набор данных. Я настроил Ajax-вызов, как показано ниже, чтобы отправить сообщение на контроллер MVC в том же приложении.

Ajax call:

ajax: {
    url: '/test',
    type: 'POST',
    contentType: 'application/json',
    dataType: 'json',
    data: function (d) {
        return JSON.stringify(d);
    }
}

Контроллер:

[Route("[controller]")]
[AllowAnonymous]
public class TestController : Controller
{
    [HttpPost]
    public IActionResult Post([FromBody]DataTablesRequest request)
    {
        // Content removed for brevity
        return Ok();
    }
}

По какой-то причине я всегда получаю обратно 400 ошибок, а действие контроллера никогда не срабатывает. Я подумал, что это может быть связано с тем, что я также реализовал .NET Identity, поэтому, возможно, это была проблема с авторизацией, но добавление атрибута [AllowAnonymous] не помогло, и я также попытался добавить xhrFields: { withCredentials: true } к вызову Ajax, который без разницы.

Кстати, модель DataTablesRequest выглядит так:

public class DataTablesRequest
{
    public int Draw { get; set; }
    public int Start { get; set; }
    public int Length { get; set; }
    public DataTablesOrder[] Order { get; set; }
    public DataTablesColumn[] Columns { get; set; }
    public DataTablesSearch Search { get; set; }
}

public class DataTablesOrder
{
    public int Column { get; set; }
    public string Dir { get; set; }
}

public class DataTablesColumn
{
    public string Data { get; set; }
    public string Name { get; set; }
    public bool Searchable { get; set; }
    public bool Orderable { get; set; }
    public DataTablesSearch Search { get; set; }
}

public class DataTablesSearch
{
    public string Value { get; set; }
    public bool Regex { get; set; }
}

... и вот пример JSON, который отправляется в теле:

{  
   "draw":1,
   "columns":[  
      {  
         "data":"col1",
         "name":"",
         "searchable":true,
         "orderable":true,
         "search":{  
            "value":"",
            "regex":false
         }
      },
      {  
         "data":"col2",
         "name":"",
         "searchable":true,
         "orderable":true,
         "search":{  
            "value":"",
            "regex":false
         }
      },
      {  
         "data":"col3",
         "name":"",
         "searchable":true,
         "orderable":true,
         "search":{  
            "value":"",
            "regex":false
         }
      },
      {  
         "data":"col4",
         "name":"",
         "searchable":true,
         "orderable":true,
         "search":{  
            "value":"",
            "regex":false
         }
      }
   ],
   "order":[  
      {  
         "column":1,
         "dir":"desc"
      }
   ],
   "start":0,
   "length":25,
   "search":{  
      "value":"",
      "regex":false
   }
}

Обновление:

Похоже, это как-то связано с SSL. Я только что отправил запрос в Почтальон и проверил консоль Почтальона, которая показывает следующее:

enter image description here

Ответы [ 2 ]

0 голосов
/ 25 января 2019

Вы должны наследовать от ApiController вместо Контроллер

Пример из Начало работы с ASP.NET Web API

using ProductsApp.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Web.Http;

namespace ProductsApp.Controllers
{
    public class ProductsController : ApiController
    {
        Product[] products = new Product[] 
        { 
            new Product { Id = 1, Name = "Tomato Soup", Category = "Groceries", Price = 1 }, 
            new Product { Id = 2, Name = "Yo-yo", Category = "Toys", Price = 3.75M }, 
            new Product { Id = 3, Name = "Hammer", Category = "Hardware", Price = 16.99M } 
        };

        public IEnumerable<Product> GetAllProducts()
        {
            return products;
        }

        public IHttpActionResult GetProduct(int id)
        {
            var product = products.FirstOrDefault((p) => p.Id == id);
            if (product == null)
            {
                return NotFound();
            }
            return Ok(product);
        }
    }
}
0 голосов
/ 25 января 2019

Это потому, что ваше сообщение DataTable ajax не получает маршрут правильно.Так что для простоты сначала удалите [Route("[controller]")] из контроллера, а затем напишите следующее:

'ajax': {
     'url': '@Url.Action("Post", "Test")',
     'method': 'POST',
     'contentType': 'application/json',
     'data': function (d) {
          return JSON.stringify(d);
     }
 }

Я отправил это из рабочего кода.

Если вам нужно все это, то этоследующим образом:

var dataTable = $("#yourDataTableId").DataTable({
            'processing': true,
            'serverSide': true,
            "order": [[0, 'desc']],
            'ajax': {
                'url': '@Url.Action("Post", "Test")',
                'method': 'POST',
                'contentType': 'application/json',
                'data': function (d) {
                    return JSON.stringify(d);
                }
            },
            "lengthMenu": [[5, 10], [5, 10]],
            "lengthChange": true,
            "searching": true,
            "scrollX": true,
            fixedColumns: {
                leftColumns: 1,
                rightColumns: 1
            },
            'columns': [
                { data: "yourColumnName", name: "YourColumnName" }

                //Other columns

            ]
 });
...