Я пытаюсь передать данные JSON из клиентского браузера в действие ASP.NET MVC с помощью jQuery $ .ajax () и связать их с классом .NET с помощью пользовательского ModelBinder.
КЛИЕНТ JAVASCRIPT:
$('#btnPatientSearch').click(function() {
var patientFilter = {
LastName: 'Flinstone',
FirstName: 'Fred'
};
var jsonData = $.toJSON(patientFilter);
$.ajax({
url: '/Services/GetPatientList',
type: 'GET',
cache: false,
data: jsonData,
contentType: 'application/json; charset=utf-8',
dataType: 'json',
timeout: 10000,
error: function() {
alert('Error loading JSON=' + jsonData);
},
success: function(jsonData) {
$("#patientSearchList").fillSelect(jsonData);
}
});
КЛАСС .NET ДЛЯ ДАННЫХ JSON
[ModelBinder(typeof(JsonModelBinder))]
public class PatientFilter
{
#region Properties
public string IDNumber { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string SSN { get; set; }
public DateTime DOB { get; set; }
#endregion
}
Действие MVC
public JsonResult GetPatientList(iPatientDoc.Models.PatientFilter patientFilter)
{
ПОЛЬЗОВАТЕЛЬСКИЙ МОДЕЛЬБИНДЕР
public class JsonModelBinder : IModelBinder
{
#region IModelBinder Members
public object BindModel(ControllerContext controllerContext, ModelBindingContext bindingContext)
{
if (controllerContext == null)
throw new ArgumentNullException("controllerContext");
if (bindingContext == null)
throw new ArgumentNullException("bindingContext");
var serializer = new DataContractJsonSerializer(bindingContext.ModelType);
return serializer.ReadObject(controllerContext.HttpContext.Request.InputStream);
#endregion
}
}
Пользовательский ModelBinder вызывается правильно, но Request.InputStream пуст, поэтому нет данных для привязки к объекту PatientFilter.
Любые мысли приветствуются.
Chris