jquery ajax拒绝发送POST请求。始终发送GET

时间:2018-04-13 11:30:59

标签: jquery ajax laravel post

我遇到jQuery ajax不发送POST请求的问题。我看过的每一个问题和答案都无济于事。

我正在使用Laravel 5.4,因此jQuery内置于app.js中,我知道这不是jQuery的问题,因为我可以执行类似的ajax请求进行POST并且它们工作得很好。

以下是有问题的代码

<div class="row">
    <div class="col-sm-4 col-sm-offset-4">
        <div class="form-group">
            <button id="btn-save" class="btn btn-success btn-block btn-lg">Save &amp; Continue</button>
        </div>
    </div>
</div>
<script>
$(function() {
    $.ajaxSetup({
        headers: {
            'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
        }
    });

    $('#btn-save').click(function(e) {
        e.preventDefault();

        $.ajax({
            url: "/account-reset/qr-code/store",
            type: 'POST',
            dataType: 'json',
            data: {
                id: 'some-long-value',
            },
            success: function(response) {
                console.log(response);
                $('.row').last().hide();
            }
        });
    });
});
</script>

当我点击保存按钮时,控制台会向/ account-reset发送一个GET请求,这不是我指定的。

如果我在url的末尾添加一个尾部斜杠,它会调用正确的url,但它仍会发送一个GET请求,因此Laravel会返回405错误MethodNotAllowedHttpException

为什么ajax不会像我告诉它那样做一个POST请求?

更新 这是我的路线。你可以看到我正在使用POST请求。没有区别(控制器除外),其路线应该按原样运行

Route::prefix('account-reset')->group(function() {
    Route::post('/qr-code/{id}', 'ResetController@qrcode')->name('reset.qrcode.save');
    Route::post('/qr-code/store', 'ResetController@qrcode_store')->name('reset.qrcode.store');
});

1 个答案:

答案 0 :(得分:-1)

打开控制台并检查发布请求变量。如果您的请求是在帖子标签中发送变量,那么您应该检查您的路线。

你有其他路线,比如资源('account-reset / qr-code','YourController')或者像get('account-reset / qr-code / {variable}','YourController')?

有时候,如果你有另一条路线,那么laravel会在第一条路线停下来。

我认为,您应该更改路线的名称并保持其唯一性,然后尝试。

我希望问题能得到解决。