In Datatables 1.10 the ajax server side parameters changed from
public class DataTableParamModel
{
public string sEcho{ get; set; }
public string sSearc
Know this post is 2 years old but to those who want to use this with ASP.Net Core MVC 6. This is the converted/ upgraded answer provided by @Shoe
using Microsoft.AspNetCore.Mvc.Internal;
using Microsoft.AspNetCore.Mvc.ModelBinding;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace TrackingAndTraining.Models
{
///
/// Model Binder for DTParameterModel (DataTables)
///
public class DTModelBinder : IModelBinder
{
public Task BindModelAsync(ModelBindingContext bindingContext)
{
var request = bindingContext.ActionContext.HttpContext.Request.Form;
// Retrieve request data
var draw = Convert.ToInt32(request["draw"]);
var start = Convert.ToInt32(request["start"]);
var length = Convert.ToInt32(request["length"]);
// Search
var search = new DTSearch
{
Value = request["search[value]"],
Regex = Convert.ToBoolean(request["search[regex]"])
};
// Order
var o = 0;
var order = new List();
while (!string.IsNullOrEmpty(request["order[" + o + "][column]"]))
{
order.Add(new DTOrder
{
Column = Convert.ToInt32(request["order[" + o + "][column]"]),
Dir = request["order[" + o + "][dir]"]
});
o++;
}
// Columns
var c = 0;
var columns = new List();
while (!string.IsNullOrEmpty(request["columns[" + c + "][name]"]))
{
columns.Add(new DTColumn
{
Data = request["columns[" + c + "][data]"],
Name = request["columns[" + c + "][name]"],
Orderable = Convert.ToBoolean(request["columns[" + c + "][orderable]"]),
Searchable = Convert.ToBoolean(request["columns[" + c + "][searchable]"]),
Search = new DTSearch
{
Value = request["columns[" + c + "][search][value]"],
Regex = Convert.ToBoolean(request["columns[" + c + "][search][regex]"])
}
});
c++;
}
var result = new DTParameterModel
{
Draw = draw,
Start = start,
Length = length,
Search = search,
Order = order,
Columns = columns
};
bindingContext.Result = ModelBindingResult.Success(result);
return TaskCache.CompletedTask;
}
}
}
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace TrackingAndTraining.Models
{
[ModelBinder(BinderType = typeof(DTModelBinder))]
public class DTParameterModel
{
///
/// Draw counter. This is used by DataTables to ensure that the Ajax returns from
/// server-side processing requests are drawn in sequence by DataTables
///
public int Draw { get; set; }
///
/// Paging first record indicator. This is the start point in the current data set
/// (0 index based - i.e. 0 is the first record)
///
public int Start { get; set; }
///
/// Number of records that the table can display in the current draw. It is expected
/// that the number of records returned will be equal to this number, unless the
/// server has fewer records to return. Note that this can be -1 to indicate that
/// all records should be returned (although that negates any benefits of
/// server-side processing!)
///
public int Length { get; set; }
///
/// Global Search for the table
///
public DTSearch Search { get; set; }
///
/// Collection of all column indexes and their sort directions
///
public List Order { get; set; }
///
/// Collection of all columns in the table
///
public List Columns { get; set; }
}
///
/// Represents search values entered into the table
///
public sealed class DTSearch
{
///
/// Global search value. To be applied to all columns which have searchable as true
///
public string Value { get; set; }
///
/// true if the global filter should be treated as a regular expression for advanced
/// searching, false otherwise. Note that normally server-side processing scripts
/// will not perform regular expression searching for performance reasons on large
/// data sets, but it is technically possible and at the discretion of your script
///
public bool Regex { get; set; }
}
///
/// Represents a column and it's order direction
///
public sealed class DTOrder
{
///
/// Column to which ordering should be applied. This is an index reference to the
/// columns array of information that is also submitted to the server
///
public int Column { get; set; }
///
/// Ordering direction for this column. It will be asc or desc to indicate ascending
/// ordering or descending ordering, respectively
///
public string Dir { get; set; }
}
///
/// Represents an individual column in the table
///
public sealed class DTColumn
{
///
/// Column's data source
///
public string Data { get; set; }
///
/// Column's name
///
public string Name { get; set; }
///
/// Flag to indicate if this column is orderable (true) or not (false)
///
public bool Orderable { get; set; }
///
/// Flag to indicate if this column is searchable (true) or not (false)
///
public bool Searchable { get; set; }
///
/// Search to apply to this specific column.
///
public DTSearch Search { get; set; }
}
}
Again all credit goes to @Shoe for original post.