Menggunakan permintaan borang untuk pengesahan di Laravel.
Jul 30, 2025 am 05:04 AMGunakan Permintaan Borang untuk Mengekstrak Logik Pengesahan Borang Kompleks dari Pengawal, meningkatkan kebolehkerjaan dan kebolehgunaan semula kod. 1. Kaedah Penciptaan: Menjana kelas permintaan melalui perintah Artisan Buat: Permintaan; 2. Tentukan Peraturan: Tetapkan logik pengesahan medan dalam kaedah () kaedah; 3. Penggunaan Pengawal: Menerima permintaan secara langsung dengan kelas ini sebagai parameter, dan Laravel secara automatik mengesahkan; 4. Penghakiman Kebenaran: Kawalan Kebenaran Pengguna Melalui Kaedah ()) Kaedah; 5. Peraturan Pelarasan Dinamik: Kembalikan Peraturan Pengesahan Berbeza mengikut Kandungan Permintaan.
Apabila melakukan pengesahan bentuk di Laravel, ramai orang akan menggunakan kaedah validate()
untuk memprosesnya secara langsung di pengawal pada mulanya. Tetapi jika logik borang anda menjadi rumit, atau jika beberapa tempat perlu menggunakan semula peraturan pengesahan yang sama, anda harus mempertimbangkan menggunakan permintaan borang .

Apakah permintaan borang?
Permintaan borang adalah kelas yang disediakan oleh Laravel yang digunakan secara khusus untuk mengendalikan pengesahan permintaan. Ia menarik logik pengesahan keluar dari pengawal, menjadikan kod lebih jelas dan lebih mudah untuk dikekalkan.
Anda boleh memahaminya sebagai kelas permintaan tersuai yang mengandungi peraturan pengesahan dan logik kebenaran untuk permintaan semasa. Ia juga sangat mudah digunakan: anda hanya perlu membuat kelas, menentukan peraturan, dan kemudian gunakan kelas ini dalam pengawal untuk menerima permintaan tersebut.

Bagaimana untuk membuat dan menggunakan permintaan borang?
Kaedah penciptaan sangat mudah, hanya gunakan perintah artisan:
PHP Artisan Make: Permintaan StorePostrequest
Ini menjana fail yang terletak di app/Http/Requests/StorePostRequest.php
.

Perkara seterusnya yang perlu anda lakukan ialah mengisi peraturan pengesahan di dalamnya. Contohnya:
Peraturan Fungsi Awam () { Kembali [ 'Tajuk' => 'Diperlukan | String | Max: 255', 'badan' => 'diperlukan', ]; }
Kemudian, dalam kaedah pengawal anda, tidak lagi menggunakan Request
, tetapi gunakan StorePostRequest
yang baru anda buat:
Gunakan apl \ http \ requests \ storepostrequest; Kedai Fungsi Awam (StorePostrequest $ permintaan) { // Jalankan jawatan logik :: create ($ permintaan-> disahkan ()); }
Dengan cara ini, Laravel secara automatik akan mengesahkannya untuk anda sebelum memasuki pengawal, dan jika gagal, mesej ralat akan dikembalikan secara langsung.
Penghakiman kebenaran juga boleh diletakkan di sini
Sebagai tambahan kepada medan pengesahan, permintaan borang juga boleh mengawal sama ada pengguna mempunyai kebenaran untuk mengemukakan borang ini. Sebagai contoh, jika anda ingin memastikan bahawa hanya log masuk pengguna boleh menyiarkan, anda boleh menulis Logik dalam kaedah authorize()
:
Fungsi Awam memberi kuasa () { kembali $ this-> user ()-> isAdmin (); }
Jika palsu dikembalikan di sini, Laravel secara automatik akan membuang AuthorizationException
untuk mengelakkan operasi seterusnya. Ini juga akan menguruskan penghakiman pihak berkuasa secara terpusat.
Peraturan pengesahan menyokong pelarasan dinamik
Kadang -kadang peraturan pengesahan tidak ditetapkan dan mungkin berbeza mengikut kandungan yang diminta. Sebagai contoh, apabila mengemas kini maklumat pengguna, jika pentadbir boleh mengubah peranan, tetapi pengguna biasa tidak boleh.
Keadaan ini boleh ditangani secara dinamik dalam rules()
kaedah:
Peraturan Fungsi Awam () { Kembali [ 'nama' => 'diperlukan', 'peranan' => $ this-> user ()-> isAdmin ()? 'Dalam: Admin, Pengguna': 'Dalam: Pengguna', ]; }
Ini membolehkan peraturan yang berbeza untuk digunakan mengikut situasi yang berbeza sambil menjaga pengawal bersih.
Pada dasarnya itu sahaja. Permintaan borang amat berguna apabila projek itu sedikit lebih besar dan logik pengesahan lebih kompleks. Walaupun anda sentiasa boleh menggunakan validate()
, selepas mengeluarkannya ke dalam permintaan borang, strukturnya lebih jelas dan mudah untuk ujian dan penggunaan semula.
Atas ialah kandungan terperinci Menggunakan permintaan borang untuk pengesahan di Laravel.. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

1. 2. Prestasi tinggi memerlukan pergantungan pada cache (redis), pengoptimuman pangkalan data, CDN dan giliran tak segerak; 3. Keselamatan mesti dilakukan dengan penapisan input, perlindungan CSRF, HTTPS, penyulitan kata laluan dan kawalan kebenaran; 4. Pengiklanan pilihan wang, langganan ahli, ganjaran, komisen, pembayaran pengetahuan dan model lain, terasnya adalah untuk memadankan nada komuniti dan keperluan pengguna.

Artikel ini bertujuan untuk menyelesaikan kesilapan umum dalam rangka kerja Laravel di mana parameter penghalaan lulus memadankan kaedah pengawal. Kami akan menerangkan secara terperinci mengapa menulis parameter secara langsung kepada nama kaedah pengawal dalam definisi penghalaan akan mengakibatkan kesilapan "kaedah tidak wujud", dan memberikan sintaks definisi penghalaan yang betul untuk memastikan pengawal dapat menerima dan memproses parameter penghalaan dengan betul. Di samping itu, artikel itu akan meneroka amalan terbaik untuk menggunakan kaedah HttpDelete dalam operasi penghapusan.

Artikel ini bertujuan untuk menyelesaikan cara untuk mengakses sifat -sifat mendalam yang cekap dan selamat yang berkaitan dengan model melalui laluan rentetan apabila data yang dinamik dalam komponen LaravelliveWire. Apabila anda perlu mendapatkan medan tertentu model yang berkaitan berdasarkan rentetan konfigurasi (seperti "user.name"), akses menggunakan sifat objek akan gagal. Artikel ini akan memperkenalkan fungsi penolong data_get Laravel secara terperinci dan memberikan contoh kod untuk menunjukkan cara menggunakannya untuk menyelesaikan masalah ini dengan anggun dan memastikan fleksibiliti dan keteguhan pemerolehan data.

Apabila memilih rangka kerja PHP yang sesuai, anda perlu mempertimbangkan secara komprehensif mengikut keperluan projek: Laravel sesuai untuk pembangunan pesat dan menyediakan enjin template eloquentorm dan bilah, yang mudah untuk operasi pangkalan data dan rendering bentuk dinamik; Symfony lebih fleksibel dan sesuai untuk sistem kompleks; Codeigniter adalah ringan dan sesuai untuk aplikasi mudah dengan keperluan prestasi tinggi. 2. Untuk memastikan ketepatan model AI, kita perlu memulakan dengan latihan data berkualiti tinggi, pemilihan penunjuk penilaian yang munasabah (seperti ketepatan, penarikan balik, nilai F1), penilaian prestasi biasa dan penalaan model, dan memastikan kualiti kod melalui ujian unit dan ujian integrasi, sambil terus memantau data input untuk mencegah data drift. 3. Banyak langkah diperlukan untuk melindungi privasi pengguna: menyulitkan dan menyimpan data sensitif (seperti AES

Terdapat tiga cara utama untuk menetapkan pembolehubah persekitaran dalam PHP: 1. Konfigurasi global melalui php.ini; 2. Melalui pelayan web (seperti setenv Apache atau fastcgi_param of nginx); 3. Gunakan fungsi Putenv () dalam skrip PHP. Antaranya, php.ini sesuai untuk konfigurasi global dan jarang mengubah konfigurasi, konfigurasi pelayan web sesuai untuk senario yang perlu diasingkan, dan putenv () sesuai untuk pembolehubah sementara. Dasar kegigihan termasuk fail konfigurasi (seperti php.ini atau konfigurasi pelayan web), fail .Env dimuatkan dengan perpustakaan dotenv, dan suntikan dinamik pembolehubah dalam proses CI/CD. Maklumat sensitif pengurusan keselamatan harus dielakkan dengan keras, dan disyorkan untuk digunakan.

Untuk membolehkan bekas PHP menyokong pembinaan automatik, terasnya terletak pada mengkonfigurasi proses integrasi berterusan (CI). 1. Gunakan Dockerfile untuk menentukan persekitaran PHP, termasuk imej asas, pemasangan lanjutan, pengurusan ketergantungan dan tetapan kebenaran; 2. Konfigurasi alat CI/CD seperti Gitlabci, dan tentukan peringkat binaan, ujian dan penempatan melalui fail .gitlab-ci.yml untuk mencapai pembinaan, pengujian dan penggunaan automatik; 3. Mengintegrasikan kerangka ujian seperti PHPUnit untuk memastikan ujian secara automatik dijalankan selepas perubahan kod; 4. Gunakan strategi penempatan automatik seperti Kubernet untuk menentukan konfigurasi penempatan melalui fail penyebaran.yaml; 5. Mengoptimumkan Dockerfile dan mengamalkan pembinaan pelbagai peringkat

Artikel ini secara mendalam meneroka penghantaran parameter penghalaan yang betul dan mekanisme pemadanan kaedah pengawal dalam rangka kerja Laravel. Sebagai tindak balas kepada "kaedah tidak wujud" biasa yang disebabkan oleh penulisan parameter penghalaan secara langsung kepada nama kaedah pengawal, artikel itu menghuraikan cara yang betul untuk menentukan penghalaan, iaitu, mengisytiharkan parameter dalam URI dan menerima mereka sebagai parameter bebas dalam kaedah pengawal. Pada masa yang sama, artikel ini juga menyediakan contoh kod dan cadangan mengenai amalan terbaik untuk kaedah HTTP, yang bertujuan untuk membantu pemaju membina aplikasi Laravel yang lebih mantap dan tenang.

Artikel ini membincangkan postur pemindahan parameter yang betul kaedah pengawal dalam penghalaan Laravel secara mendalam. Sebagai tindak balas kepada kesilapan biasa yang disebabkan oleh menulis parameter penghalaan secara langsung kepada nama kaedah pengawal, sintaks definisi penghalaan yang betul dijelaskan secara terperinci, dan mekanisme parameter automatik Laravel mengikat ditekankan. Pada masa yang sama, artikel itu mengesyorkan menggunakan kaedah httpDelete yang lebih selaras dengan spesifikasi yang tenang untuk mengendalikan operasi penghapusan untuk meningkatkan pemeliharaan dan semantik permohonan.
