Bagaimana untuk menetapkan kebenaran pasukan projek ThinkPHP
1 Memahami tetapan kebenaran ThinkPHP
Tetapan kebenaran merujuk kepada peruntukan kebenaran operasi mengikut julat kebenaran pengguna supaya mereka boleh melakukan tindakan yang sepadan beroperasi . Dalam rangka kerja ThinkPHP, tetapan kebenaran boleh dilaksanakan melalui RBAC (Role-Based Access Control). Kawalan capaian berasaskan peranan (RBAC) ialah model kawalan capaian yang memberikan kebenaran berdasarkan peranan dan bukannya pengguna dan memberi pengguna kebenaran akses dengan menetapkan peranan. RBAC mempunyai ciri-ciri berikut:
Berikan kebenaran kepada peranan, dan kemudian tetapkan peranan kepada pengguna untuk pengurusan yang mudah;
Pengguna hanya perlu mempunyai peranan. Anda boleh memiliki semua kebenaran yang dimiliki oleh peranan; > melaksanakan kebenaran Pemisahan daripada logik perniagaan meningkatkan penggunaan semula kod dan keselamatan akses dengan ketara.
- 2 langkah tetapan kebenaran berasaskan RBAC
Langkah 1 Cipta jadual kebenaran
Dalam Buat jadual kebenaran dalam pangkalan data, termasuk medan id, nama, tajuk dan status; medan tajuk ialah nama kebenaran;
- medan status ialah status kebenaran, 1 bermaksud didayakan, 0 bermaksud dilumpuhkan.
- Langkah 2 Buat jadual peranan
- Buat jadual peranan dalam pangkalan data, termasuk id medan, nama, tajuk dan status
- Medan id dan nama ialah kunci utama dan pengecam peranan; >
- Medan status ialah status peranan, 1 bermakna didayakan, 0 bermakna dilumpuhkan.
- Buat jadual pengguna dalam pangkalan data, termasuk id medan, nama pengguna, kata laluan dan status
- medan id ialah kunci utama;
- nama pengguna ialah nama pengguna;
- status mewakili status pengguna, 1 mewakili didayakan, 0 mewakili dilumpuhkan.
- Buat jadual persatuan peranan pengguna dalam pangkalan data, termasuk medan user_id dan role_id; 🎜 > user_id ialah ID pengguna;
- Langkah 5 Buat jadual persatuan kebenaran peranan
- Buat jadual persatuan kebenaran peranan dalam pangkalan data, termasuk medan role_id dan rule_id
- role_id ialah ID peranan;
- Langkah 6 Laksanakan kawalan kebenaran
Dalam projek ThinkPHP, kaedah untuk melaksanakan kawalan kebenaran adalah seperti berikut:
Dalam projek Tentukan pengawal awam CommonController, yang boleh melaksanakan kawalan kebenaran untuk semua pengguna; > dalam Kawalan kebenaran dilakukan dalam kelas CommonController, seperti yang ditunjukkan di bawah:
public function _initialize(){ if(!authcheck()){ } } public function authcheck(){ $auth=new Auth; if($auth->check(MODULE_NAME.'/'.CONTROLLER_NAME.'/'.ACTION_NAME,session('uid'))){ return true; }else{ return false; } }
Salin selepas log masukDalam kelas Auth, logik pengesahan kebenaran dilaksanakan, seperti ditunjukkan di bawah : class Auth { //检查权限 public function check($name, $uid){ if(in_array($uid, C('AUTH_SUPER_ADMIN'))){ return true; } $infos=M('user')->field('role_id')->where('id='.$uid)->find(); $role_id=$infos['role_id']; $rules=M('access')->where('role_id='.$role_id)->select(); foreach($rules as $v){ $rule_ids[]=$v['rule_id']; } $rules=M('rule')->where('id in ('.implode(',',$rule_ids).')')->select(); foreach($rules as $r){ $urls[]=$r['name']; } if(in_array($name,$urls)){ return true; }else{ return false; } } }
Salin selepas log masukLogik yang dilaksanakan oleh kod di atas adalah untuk menambah pengesahan kebenaran untuk semua permintaan operasi pengguna. Pengesah akan terlebih dahulu menyemak sama ada pengguna mempunyai keistimewaan pentadbir super apabila meminta operasi yang memerlukan kawalan kebenaran. Jika pengguna ialah pentadbir super, ujian itu diluluskan secara langsung jika pengguna bukan pentadbir super, senarai ID kebenaran yang dimiliki oleh peranan ditemui (ditanya dari jadual persatuan) berdasarkan ID peranan pengguna (ditanya daripada jadual pengguna), dan kemudian Cari senarai nama kebenaran yang sepadan berdasarkan senarai ID kebenaran jika nama operasi yang diminta berada dalam senarai nama kebenaran, pengesahan diluluskan jika tidak, pengesahan kebenaran gagal;
Atas ialah kandungan terperinci Bagaimana untuk menetapkan kebenaran pasukan projek ThinkPHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

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



Untuk menjalankan projek ThinkPHP, anda perlu: memasang Komposer untuk mencipta projek, masukkan direktori projek dan laksanakan php bin/console serve;

ThinkPHP mempunyai berbilang versi yang direka untuk versi PHP yang berbeza. Versi utama termasuk 3.2, 5.0, 5.1 dan 6.0, manakala versi kecil digunakan untuk membetulkan pepijat dan menyediakan ciri baharu. Versi stabil terkini ialah ThinkPHP 6.0.16. Apabila memilih versi, pertimbangkan versi PHP, keperluan ciri dan sokongan komuniti. Adalah disyorkan untuk menggunakan versi stabil terkini untuk prestasi dan sokongan terbaik.

Langkah-langkah untuk menjalankan ThinkPHP Framework secara setempat: Muat turun dan nyahzip ThinkPHP Framework ke direktori tempatan. Buat hos maya (pilihan) yang menunjuk ke direktori akar ThinkPHP. Konfigurasikan parameter sambungan pangkalan data. Mulakan pelayan web. Mulakan aplikasi ThinkPHP. Akses URL aplikasi ThinkPHP dan jalankannya.

Perbandingan prestasi rangka kerja Laravel dan ThinkPHP: ThinkPHP umumnya berprestasi lebih baik daripada Laravel, memfokuskan pada pengoptimuman dan caching. Laravel berfungsi dengan baik, tetapi untuk aplikasi yang kompleks, ThinkPHP mungkin lebih sesuai.

"Cadangan Pembangunan: Cara Menggunakan Rangka Kerja ThinkPHP untuk Melaksanakan Tugas Asynchronous" Dengan perkembangan pesat teknologi Internet, aplikasi Web mempunyai keperluan yang semakin tinggi untuk mengendalikan sejumlah besar permintaan serentak dan logik perniagaan yang kompleks. Untuk meningkatkan prestasi sistem dan pengalaman pengguna, pembangun sering mempertimbangkan untuk menggunakan tugas tak segerak untuk melaksanakan beberapa operasi yang memakan masa, seperti menghantar e-mel, memproses muat naik fail, menjana laporan, dsb. Dalam bidang PHP, rangka kerja ThinkPHP, sebagai rangka kerja pembangunan yang popular, menyediakan beberapa cara mudah untuk melaksanakan tugas tak segerak.

Langkah pemasangan ThinkPHP: Sediakan persekitaran PHP, Komposer dan MySQL. Buat projek menggunakan Komposer. Pasang rangka kerja dan kebergantungan ThinkPHP. Konfigurasikan sambungan pangkalan data. Hasilkan kod aplikasi. Lancarkan aplikasi dan lawati http://localhost:8000.

ThinkPHP ialah rangka kerja PHP berprestasi tinggi dengan kelebihan seperti mekanisme caching, pengoptimuman kod, pemprosesan selari dan pengoptimuman pangkalan data. Ujian prestasi rasmi menunjukkan bahawa ia boleh mengendalikan lebih daripada 10,000 permintaan sesaat, dan digunakan secara meluas dalam tapak web dan sistem perusahaan berskala besar seperti JD.com dan Ctrip dalam aplikasi praktikal.

Perkhidmatan RPC berdasarkan ThinkPHP6 dan Swoole melaksanakan fungsi pemindahan fail Pengenalan: Dengan perkembangan Internet, pemindahan fail menjadi semakin penting dalam kerja harian kita. Untuk meningkatkan kecekapan dan keselamatan pemindahan fail, artikel ini akan memperkenalkan kaedah pelaksanaan khusus perkhidmatan RPC berdasarkan ThinkPHP6 dan Swoole untuk melaksanakan fungsi pemindahan fail. Kami akan menggunakan ThinkPHP6 sebagai rangka kerja web dan menggunakan fungsi RPC Swoole untuk mencapai pemindahan fail silang pelayan. 1. Standard alam sekitar
