AntiforgeryToken генерация от использования @ Ajax .BeginForm () - PullRequest
0 голосов
/ 03 марта 2020

У меня проблема с созданием токена защиты от подделки вручную внутри ajax методов. Поэтому мой вопрос Если я использовал ajax .beginform (), генерирует ли он токен, такой как @ html .beginform? Если так, как я могу использовать его с моими ajax методами?

Пожалуйста, игнорируйте длинный код в представлении. Моя главная проблема - методы ajax. Я разместил его, чтобы показать вам представление в случае предложения использовать beginForm ().

@*@Html.AntiForgeryToken()*@
<hr />
<div class="row">
    <div class="col-lg-6">
        <label><strong>Month:</strong></label>
    </div>
    <div class="col-lg-6">
        <label>@manning_HQ.Issue_Date</label>
    </div>
</div>
<div class="row">
    <div class="col-lg-6">
        <label><strong>Count:</strong></label>
    </div>
    <div class="col-lg-6">
        <label>@manning_HQ.Count</label>
    </div>
</div>
<div class="row">
    <div class="col-lg-6">
        <label><strong>Location:</strong></label>
    </div>
    <div class="col-lg-6">
        <label>@manning_HQ.Location_Name</label>
    </div>
</div>


<hr />
<div class="col-lg-4">
    <label>Recruitment Status :</label>
</div>
<div class="col-lg-3">
    <select id="recruitment_Status">
        <option value="0">
            Choose Status
        </option>
        @foreach (TBL_Recruitment_Status rec in recruitment_Status)
        {
            <option  value="@rec.Rec_Status_ID">
                @rec.Status_Name
            </option>
        }
    </select>
</div>
<div class="row">

    <div class="col-lg-12">

        <label><strong>Issue staff requisition:</strong></label>
    </div>
</div>
<div class="row">
    <div class="col-lg-6">
        <input type="radio" name="Decision" id="_123" value="Accepted" />
        Accepted
    </div>
    <div class="col-lg-6">
        <input type="radio" name="Decision" id="_456" value="Rejected" />
        Rejected
    </div>
</div>
<hr />

<div class="row" id="RejComment" hidden>
    <div class="col-lg-6">
        <label>Rejected Comment :</label>
    </div>
    <div class="col-lg-3">
        <textarea id="RetainedComment"></textarea>
    </div>
</div>
<br />

<div class="modal-footer" id="Save_Dicision" hidden>
    <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
    <button type="button" class="btn btn-primary" onclick="saveDecision(@manning_HQ.Issue_Staff_ID)">Save</button>
</div>

<script>
    var DecesionCheck = false;
    var rejected = false;
    var reason = false;

    $(document).ready(function () {
        $('input[type=radio][name=Decision]').change(function () {
            if ($("input[name='Decision']:checked").val() == 'Accepted') {
                $('#RejComment').hide();
                $('#Save_Dicision').show();
                rejected = true;
            }
            if ($("input[name='Decision']:checked").val() == 'Rejected') {
                $('#RejComment').show();
                $('#Save_Dicision').show();

                rejected = true;
            }
        });
    });
    function saveDecision(ID) {
        var Decsion = $('input[name=Decision]:checked').val();
        var Reason = $('#recruitment_Status').val();
        //var token = $("[name='__RequestVerificationToken']").val();
        if (Decsion == "#_123") {
            if (DecesionCheck == true) {
                var Decsion = $('input[name=Decision]:checked').val();
                var optionalComment = $('#OptionalComment').val();
                $.ajax({
                    type: 'POST',
                    url: '/Staff_Requisition_HQ/Recruitment_Actions', 
                    data: {
                       // __RequestVerificationToken: token,
                        Issue_Staff_ID: ID,
                        Rec_Status_ID: Reason,
                        OpComment: RetainedComment,
                        RecDecison: Decsion,
                    },
                    success: function (result) {
                        $('#DescionDetailsPOPUP').modal('hide');
                        location.reload();
                    },
                    fail: function (xhr, textStatus, errorThrown) {
                        alert('request failed');
                    }
                });
            }


        }
        else {

            var Decsion = $('input[name=Decision]:checked').val();
            var RetainedComment = $('#RetainedComment').val();

            $.ajax({
                type: 'POST',
                url: '/Staff_Requisition_HQ/Recruitment_Actions',
                data: {
                    //__RequestVerificationToken: token,
                    Issue_Staff_ID: ID,
                    Rec_Status_ID: Reason,
                    Comment: RetainedComment, 
                    RecDecison: Decsion,

                },
                success: function (result) {
                    $('#DescionDetailsPOPUP').modal('hide');
                    location.reload();
                },
                fail: function (xhr, textStatus, errorThrown) {
                    alert('request failed');
                }
            });
        }

    }

</script>

1 Ответ

0 голосов
/ 03 апреля 2020

Вот пример Ajax.BeginForm из одного из моих просмотров:

<!-- FORM Atributo -->
@using (Ajax.BeginForm(accionFormulario, "Atributos", new AjaxOptions() { OnSuccess = "onSuccessCreate" }, new { @id = "frmCreate" }))
{
    @Html.AntiForgeryToken()
    @Html.HiddenFor(model => model.AtributoId)
    @Html.HiddenFor(model => model.EmpresaId)

    <div class="modal-body">
        <div class="row">
            // the form inputs ....
        </div>
    </div>

    <div class="modal-footer">
        <button class="btn btn-secondary mx-1" type="button" data-dismiss="modal" aria-label="Close">@Global.Cancelar</button>
        <button class="btn btn-primary" type="submit"><strong>@Global.Guardar</strong></button>
    </div>
}

Это генерирует AntiForgeryToken, как и ожидалось: enter image description here

Вы можете захватить это с javascript, как вы делали в вашем представлении.

...