Memahami dan Menyelesaikan Ralat Ajax Laravel 419 POST
Ralat Laravel 419 POST ialah isu biasa yang timbul dalam permintaan Ajax. Ia berlaku kerana token perlindungan CSRF (Cross-Site Request Forgery) tiada dalam pengepala permintaan. Laravel melaksanakan perlindungan CSRF secara lalai untuk menghalang permintaan hasad daripada sumber luaran.
Punca Punca Ralat 419
Laravel menjana token CSRF unik untuk setiap sesi pengguna aktif. Token ini digunakan untuk mengesahkan bahawa pengguna yang disahkan adalah yang membuat permintaan. Jika permintaan tidak mengandungi token CSRF yang betul, Laravel akan mengembalikan ralat 419.
Konfigurasi Panggilan Ajax
Dalam panggilan Ajax yang disediakan, X-CSRF- Pengepala TOKEN tiada. Tambahkan baris ini pada persediaan panggilan Ajax anda untuk memasukkan token dalam setiap permintaan:
<code class="javascript">$.ajaxSetup({ headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') } });</code>
Ini memastikan token CSRF disertakan dalam setiap permintaan Ajax, menjadikannya serasi dengan perlindungan CSRF Laravel.
Penyelesaian Alternatif: Tidak Termasuk Laluan daripada Pengesahan CSRF
Sebagai alternatif, anda boleh mengecualikan laluan tertentu daripada pengesahan token CSRF dalam perisian tengah VerifyCSRFToken. Dalam app/Http/Kernel.php, tambahkan laluan yang diingini pada sifat $except:
<code class="php">protected $except = [ '/route_you_want_to_ignore', '/route_group/* ];</code>
Ini akan mengecualikan laluan yang ditentukan daripada pengesahan token CSRF, membolehkan mereka memintas ralat 419 untuk permintaan Ajax.
Kesimpulan
Dengan memasukkan token CSRF dalam permintaan Ajax atau mengecualikan laluan daripada pengesahan CSRF, anda boleh menyelesaikan ralat Ajax Laravel 419 POST dengan berkesan dan memastikan integriti daripada permintaan permohonan anda.
Atas ialah kandungan terperinci Mengapa Saya Mendapat Ralat 419 POST dalam Permintaan Laravel Ajax Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!