Ответ 1
Вам понадобится помощник Html.AntiForgeryToken
, который устанавливает cookie и испускает скрытое поле с тем же значением. При отправке запроса AJAX вам необходимо также добавить это значение в данные POST.
Итак, я бы использовал обычную ссылку вместо ссылки Ajax:
@Html.ActionLink(
"Delete",
"Delete",
"LabTest",
new {
id = item.LabTestID
},
new {
@class = "delete",
data_confirm = "Are You sure You want to delete (" + item.Description.ToString() + ") ?"
}
)
а затем поместите скрытое поле где-нибудь в DOM (например, перед закрывающим тегом body):
@Html.AntiForgeryToken()
и, наконец, ненавязчиво AJAXify анкер удаления:
$(function () {
$('.delete').click(function () {
if (!confirm($(this).data('confirm'))) {
return false;
}
var token = $(':input:hidden[name*="RequestVerificationToken"]');
var data = { };
data[token.attr('name')] = token.val();
$.ajax({
url: this.href,
type: 'POST',
data: data,
success: function (result) {
},
error: function () {
}
});
return false;
});
});
Теперь вы можете украсить свое действие Delete
атрибутом ValidateAntiForgeryToken
:
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Delete(int id)
{
...
}