जब मैंने MVC कार्रवाई के लिए DataTable में कई चयनित पंक्तियों से कुछ डेटा भेजने का प्रयास किया तो मैंने क्या किया:
HTML पृष्ठ की शुरुआत में:
@Html.AntiForgeryToken()
(बस एक पंक्ति दिखाई गई है, मॉडल से बांधें):
@foreach (var item in Model.ListOrderLines)
{
<tr data-orderid="@item.OrderId" data-orderlineid="@item.OrderLineId" data-iscustom="@item.IsCustom">
<td>@item.OrderId</td>
<td>@item.OrderDate</td>
<td>@item.RequestedDeliveryDate</td>
<td>@item.ProductName</td>
<td>@item.Ident</td>
<td>@item.CompanyName</td>
<td>@item.DepartmentName</td>
<td>@item.ProdAlias</td>
<td>@item.ProducerName</td>
<td>@item.ProductionInfo</td>
</tr>
}
जावास्क्रिप्ट फ़ंक्शन शुरू करने वाला बटन:
<button class="btn waves-effect waves-light btn-success" onclick="ProcessMultipleRows();">Start</button>
जावास्क्रिप्ट फ़ंक्शन:
function ProcessMultipleRows() {
if ($(".dataTables_scrollBody>tr.selected").length > 0) {
var list = [];
$(".dataTables_scrollBody>tr.selected").each(function (e) {
var element = $(this);
var orderid = element.data("orderid");
var iscustom = element.data("iscustom");
var orderlineid = element.data("orderlineid");
var folderPath = "";
var fileName = "";
list.push({ orderId: orderid, isCustomOrderLine: iscustom, orderLineId: orderlineid, folderPath: folderPath, fileName : fileName});
});
$.ajax({
url: '@Url.Action("StartWorkflow","OrderLines")',
type: "post", //<------------- this is important
data: { model: list }, //<------------- this is important
beforeSend: function (xhr) {//<--- This is important
xhr.setRequestHeader("RequestVerificationToken",
$('input:hidden[name="__RequestVerificationToken"]').val());
showPreloader();
},
success: function (data) {
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
},
complete: function () {
hidePreloader();
}
});
}
}
एमवीसी कार्रवाई:
[HttpPost]
[ValidateAntiForgeryToken] //<--- This is important
public async Task<IActionResult> StartWorkflow(IEnumerable<WorkflowModel> model)
और C # में मॉडल:
public class WorkflowModel
{
public int OrderId { get; set; }
public int OrderLineId { get; set; }
public bool IsCustomOrderLine { get; set; }
public string FolderPath { get; set; }
public string FileName { get; set; }
}
निष्कर्ष:
त्रुटि का कारण:
"Failed to load resource: the server responded with a status of 400 (Bad Request)"
विशेषता है: [ValidateAntiForgeryToken]
एमवीसी कार्रवाई के लिएStartWorkflow
Ajax कॉल में समाधान:
beforeSend: function (xhr) {//<--- This is important
xhr.setRequestHeader("RequestVerificationToken",
$('input:hidden[name="__RequestVerificationToken"]').val());
},
ऑब्जेक्ट्स की सूची भेजने के लिए आपको उदाहरण में डेटा बनाने की आवश्यकता है (सूची ऑब्जेक्ट को पॉप्युलेट करना) और:
डेटा: {मॉडल: सूची},
प्रकार: "पोस्ट",