ajax - 如何通过laravel中的ajax调用发送csrf token ?

标签 ajax laravel-5 token csrf mismatch

我有一个带有 method=post 的表单。在那个表单中,我有一个图像上传字段,它是 ajax。当 ajax 调用过程中,验证 csrf token 不匹配错误发生。帮助我。这是我的代码..,

<script>
            $(document).ready(function(){
                $(document).on("click", "#upload", function() {
                    var file_data = $("#groupe_img").prop("files")[0];   // Getting the properties of file from file field
                    var form_data = new FormData();                  // Creating object of FormData class
                    form_data.append("file", file_data)              // Appending parameter named file with properties of file_field to form_data
                    form_data.append("csrftoken",document.mainform.csrftoken.value;)                 // Adding extra parameters to form_data
                    $.ajax({
                                url: "/upload_avatar",
                                dataType: 'script',
                                cache: false,
                                contentType: false,
                                processData: false,
                                data: form_data,                         // Setting the data attribute of ajax with file_data
                                type: 'post'
                       })
                })
            });
        </script>

这是我的 html 部分
<input type="file" name="groupe_img" id="groupe_img">
<button id="upload" value="Upload">upload image</button>

气喘吁吁

最佳答案

先加csrf标记到这样的元标记(在主布局中,例如:head 部分中的 resources/views/default.blade.php):

<meta name="_token" content="{{ csrf_token() }}"/>

然后使用 $.ajaxSetup在ajax调用之前:
$.ajaxSetup({
    headers: {
        'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content')
    }
});

$.ajax({
    url: "/upload_avatar",
    dataType: 'script',
    cache: false,
    contentType: false,
    processData: false,
    data: form_data,
    type: 'post'
})

关于ajax - 如何通过laravel中的ajax调用发送csrf token ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34586560/

相关文章:

javascript - 从 CouchDB Show Function 发出 AJAX 请求

javascript - jQuery AJAX GET 请求调用不正确

php - 如何使用 laravel 5 Eloquent 模型在第三张表的基础上获取第一张表记录

php - 在哪里指定 Laravel 应用程序的应用程序版本?

php - Laravel 5 忽略身份验证特定路由

javascript - 使用jquery访问json数据来设置值

javascript - 如何在 Laravel 中调用 ajax 后重定向到登录?

php - 为什么在 Laravel 5.2 中显示没有变量值的空页面

java - 在分析 Lucene 文档字段标记后,如何获取它们的术语?

java - 在 Java 中读取 token