Rumah rangka kerja php YII Pengurusan kebenaran RBAC dalam rangka kerja Yii: mengawal kebenaran akses pengguna

Pengurusan kebenaran RBAC dalam rangka kerja Yii: mengawal kebenaran akses pengguna

Jun 21, 2023 am 10:43 AM
rangka kerja yii pengurusan kebenaran rbac Hak akses pengguna

Dengan pembangunan Internet yang berterusan, semakin banyak laman web dan aplikasi perlu melaksanakan pengurusan dan kawalan kebenaran pengguna untuk memastikan keselamatan dan kebolehpercayaan tapak web dan aplikasi. Sebagai rangka kerja PHP yang popular, rangka kerja Yii menyediakan set lengkap mekanisme pengurusan kebenaran RBAC (Role-Based Access Control) untuk mengawal kebenaran akses pengguna kepada sistem. Artikel ini akan memperkenalkan mekanisme pengurusan kebenaran RBAC dalam rangka kerja Yii dan menunjukkan penggunaannya dengan contoh mudah.

1 Pengenalan kepada mekanisme pengurusan kebenaran RBAC

RBAC ialah mekanisme kawalan akses berasaskan peranan Dengan mengaitkan pengguna dan kebenaran kepada peranan masing-masing, hubungan antara pengguna dan kebenaran direalisasikan dalam peranan. proses kebenaran. Dalam RBAC, kebenaran dibahagikan kepada operasi, objek dan peraturan. Operasi merujuk kepada operasi pada data, seperti mencipta, membaca, mengemas kini, memadam, dsb. Objek merujuk kepada data yang perlu dikendalikan, seperti artikel, ulasan, pengguna, dll. Peraturan ialah beberapa sekatan ke atas kebenaran, seperti sama ada ini Pemilik data, dsb. Peranan ialah koleksi kebenaran pengguna, yang terdiri daripada berbilang kebenaran Ia biasanya termasuk set operasi, satu set kebenaran objek dan beberapa peraturan. Dalam rangka kerja Yii, RBAC dilaksanakan melalui CPhpAuthManager.

2. Operasi asas pengurusan kebenaran RBAC

Pertama, kita perlu menambah kebenaran dan peranan pada sistem. Ini boleh dicapai dengan menambahkan kebenaran dan peranan baharu dalam objek pengurusan kebenaran CPhpAuthManager dalam rangka kerja Yii. Berikut ialah contoh kod untuk menambah kebenaran baharu:

// 添加新权限
$auth=Yii::app()->authManager; 
$auth->createOperation('createPost','create a new post'); 
$auth->createOperation('readPost','read a post'); 
$auth->createOperation('updatePost','update a post'); 
$auth->createOperation('deletePost','delete a post'); 
Salin selepas log masuk

Dalam kod di atas, kami telah menambah empat kebenaran baharu: mencipta artikel, membaca artikel, mengemas kini artikel dan memadamkan artikel.

Seterusnya, kita perlu menentukan peranan dan menambah kebenaran pada peranan itu. Kod berikut menunjukkan cara menambah kebenaran di atas pada peranan bernama "admin":

// 添加一个新角色,将权限添加到角色中
$auth=Yii::app()->authManager; 
$role=$auth->createRole('admin'); 
$role->addChild('createPost'); 
$role->addChild('readPost'); 
$role->addChild('updatePost'); 
$role->addChild('deletePost'); 
Salin selepas log masuk

Dalam kod di atas, kami mentakrifkan peranan bernama "admin" dan menambah empat kebenaran di atas Tambahkan pada peranan ini.

Akhir sekali, semasa memproses permintaan akses pengguna, kami perlu menyemak sama ada pengguna mempunyai kebenaran yang sepadan. Kod berikut menunjukkan cara untuk menyemak sama ada pengguna mempunyai kebenaran "createPost":

//检查用户是否具有createPost权限
$auth=Yii::app()->authManager; 
if($auth->checkAccess('createPost',$userId))
{
    // 用户具有权限,进行操作
}
else
{
    // 用户不具有权限,返回错误
}
Salin selepas log masuk

Dalam kod di atas, kami mula-mula mendapatkan objek pengurusan kebenaran $auth, dan kemudian memanggil kaedah checkAccess untuk menyemak sama ada pengguna mempunyai kebenaran createPost. Jika pengguna mempunyai kebenaran ini, operasi yang sepadan boleh dilakukan, jika tidak mesej ralat perlu dikembalikan.

3. Contoh pengurusan kebenaran RBAC

Andaikan kami mempunyai laman web blog ini mengandungi tiga entiti asas: artikel, ulasan dan pengguna Kami perlu mengawal hak akses pengguna kepada tiga entiti ini. Dalam contoh ini, kami akan menentukan dua peranan asas: Pentadbir dan Pengguna Biasa. Pentadbir telah membuat, membaca, mengemas kini dan memadam kebenaran pada semua entiti, manakala pengguna biasa hanya mempunyai kebenaran membaca pada artikel dan ulasan.

Mula-mula, konfigurasikan komponen pengurusan kebenaran RBAC dalam fail konfigurasi rangka kerja Yii:

'authManager'=>array(
    'class' => 'CDbAuthManager',
    'connectionID' => 'db',
    'itemTable' => '{{authitem}}',
    'assignmentTable' => '{{authassignment}}',
    'itemChildTable' => '{{authitemchild}}',
),
Salin selepas log masuk

Kemudian, dalam pengawal kami, tambahkan kod berikut untuk menambah kebenaran dan peranan baharu:

$auth = Yii::app()->authManager;

// 添加新权限
$auth->createOperation('createArticle', 'create a new article');
$auth->createOperation('readArticle', 'read an article');
$auth->createOperation('updateArticle', 'update an article');
$auth->createOperation('deleteArticle', 'delete an article');
$auth->createOperation('createComment', 'create a new comment');
$auth->createOperation('readComment', 'read a comment');
$auth->createOperation('updateComment', 'update a comment');
$auth->createOperation('deleteComment', 'delete a comment');

// 添加新角色
$roleAdmin = $auth->createRole('admin');
$roleAdmin->addChild('createArticle');
$roleAdmin->addChild('readArticle');
$roleAdmin->addChild('updateArticle');
$roleAdmin->addChild('deleteArticle');
$roleAdmin->addChild('createComment');
$roleAdmin->addChild('readComment');
$roleAdmin->addChild('updateComment');
$roleAdmin->addChild('deleteComment');

$roleUser = $auth->createRole('user');
$roleUser->addChild('readArticle');
$roleUser->addChild('readComment');

// 将角色分配给用户
$auth->assign('admin', 1);
$auth->assign('user', 2);
Salin selepas log masuk

Dalam kod di atas, kami mula-mula mencipta lapan kebenaran baharu, yang digunakan untuk mengawal operasi CRUD artikel dan ulasan. Kemudian, kami menentukan dua peranan baharu: pentadbir dan pengguna, dan menambahkan kebenaran yang sepadan pada peranan tersebut. Akhir sekali, kami memberikan peranan pentadbir kepada pengguna 1 dan peranan pengguna kepada pengguna 2.

Seterusnya, dalam pengawal, kita boleh menyemak sama ada pengguna mempunyai kebenaran yang sepadan dengan memanggil kaedah checkAccess dan melaksanakan operasi yang sepadan, seperti yang ditunjukkan dalam kod berikut:

if(Yii::app()->user->checkAccess('createArticle'))
{
    // 当前用户具有创建文章权限,进行相应操作
}

if(Yii::app()->user->checkAccess('readArticle'))
{
    // 当前用户具有读取文章权限,进行相应操作
}

if(Yii::app()->user->checkAccess('updateArticle'))
{
    // 当前用户具有更新文章权限,进行相应操作
}

if(Yii::app()->user->checkAccess('deleteArticle'))
{
    // 当前用户具有删除文章权限,进行相应操作
}

if(Yii::app()->user->checkAccess('createComment'))
{
    // 当前用户具有创建评论权限,进行相应操作
}

if(Yii::app()->user->checkAccess('readComment'))
{
    // 当前用户具有读取评论权限,进行相应操作
}

if(Yii::app()->user->checkAccess('updateComment'))
{
    // 当前用户具有更新评论权限,进行相应操作
}

if(Yii::app()->user->checkAccess('deleteComment'))
{
    // 当前用户具有删除评论权限,进行相应操作
}
Salin selepas log masuk

Kod di atas , kami menyemak sama ada pengguna mempunyai kebenaran yang sepadan dengan memanggil kaedah checkAccess dan melaksanakan operasi yang sepadan apabila mempunyai kebenaran yang sepadan. Contohnya, apabila pengguna mempunyai kebenaran untuk mencipta artikel, kami boleh melakukan operasi cipta artikel yang sepadan.

4. Kesimpulan

Melalui pengenalan artikel ini, kita dapat melihat bahawa rangka kerja Yii menyediakan set lengkap mekanisme pengurusan kebenaran RBAC untuk mengawal kebenaran akses pengguna kepada sistem. Dengan mentakrifkan peranan dan menambahkan kebenaran pada peranan, kami boleh mengawal akses pengguna kepada entiti dalam sistem dengan mudah. Sudah tentu, sebagai tambahan kepada mekanisme pengurusan kebenaran RBAC, rangka kerja Yii juga menyediakan banyak ciri keselamatan lain, seperti penyulitan kata laluan, menghalang pemalsuan permintaan merentas tapak, dan lain-lain, yang boleh dipilih oleh pembangun untuk digunakan mengikut situasi sebenar.

Atas ialah kandungan terperinci Pengurusan kebenaran RBAC dalam rangka kerja Yii: mengawal kebenaran akses pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pembangunan API RESTful dalam rangka kerja Yii Pembangunan API RESTful dalam rangka kerja Yii Jun 21, 2023 pm 12:34 PM

Yii ialah rangka kerja MVC berprestasi tinggi berdasarkan PHP Ia menyediakan set alat dan fungsi yang sangat kaya untuk menyokong pembangunan aplikasi web yang pantas dan cekap. Antaranya, fungsi RESTfulAPI bagi rangka kerja Yii telah menarik lebih banyak perhatian dan kasih sayang pembangun, kerana menggunakan rangka kerja Yii boleh membina antara muka RESTful berprestasi tinggi dan mudah berskala, memberikan sokongan kuat untuk pembangunan aplikasi web. Pengenalan kepada RESTfulAPI RESTfulAPI ialah a

Cara menggunakan rangka kerja Yii dalam PHP Cara menggunakan rangka kerja Yii dalam PHP Jun 27, 2023 pm 07:00 PM

Dengan perkembangan pesat aplikasi web, pembangunan web moden telah menjadi kemahiran penting. Banyak rangka kerja dan alatan tersedia untuk membangunkan aplikasi web yang cekap, antaranya rangka kerja Yii adalah yang sangat popular. Yii ialah rangka kerja PHP berasaskan komponen berprestasi tinggi yang menggunakan corak dan teknologi reka bentuk terkini, menyediakan alatan dan komponen yang berkuasa serta sesuai untuk membina aplikasi web yang kompleks. Dalam artikel ini, kita akan membincangkan cara menggunakan rangka kerja Yii untuk membina aplikasi web. Pasang rangka kerja Yii dahulu,

Langkah-langkah untuk melaksanakan caching halaman web dan chunking halaman menggunakan rangka kerja Yii Langkah-langkah untuk melaksanakan caching halaman web dan chunking halaman menggunakan rangka kerja Yii Jul 30, 2023 am 09:22 AM

Langkah-langkah untuk melaksanakan caching halaman web dan chunking halaman menggunakan rangka kerja Yii Pengenalan: Semasa proses pembangunan web, untuk meningkatkan prestasi dan pengalaman pengguna tapak web, selalunya perlu untuk cache dan chunk halaman. Rangka kerja Yii menyediakan fungsi caching dan reka letak yang berkuasa, yang boleh membantu pembangun melaksanakan caching halaman web dan chunking halaman dengan pantas Artikel ini akan memperkenalkan cara menggunakan rangka kerja Yii untuk melaksanakan caching halaman web dan chunking halaman. 1. Hidupkan caching halaman web Dalam rangka kerja Yii, caching halaman web boleh dihidupkan melalui fail konfigurasi. Buka fail konfigurasi utama co

Buat tapak web panduan permainan menggunakan rangka kerja Yii Buat tapak web panduan permainan menggunakan rangka kerja Yii Jun 21, 2023 pm 01:45 PM

Dalam beberapa tahun kebelakangan ini, dengan perkembangan pesat industri permainan, semakin ramai pemain telah mula mencari strategi permainan untuk membantu mereka melepasi permainan. Oleh itu, mencipta laman web panduan permainan boleh memudahkan pemain mendapatkan panduan permainan, dan pada masa yang sama, ia juga boleh memberikan pemain pengalaman permainan yang lebih baik. Apabila mencipta tapak web sedemikian, kita boleh menggunakan rangka kerja Yii untuk pembangunan. Rangka kerja Yii ialah rangka kerja pembangunan aplikasi web berdasarkan bahasa pengaturcaraan PHP. Ia mempunyai ciri kecekapan tinggi, keselamatan dan kebolehskalaan yang kukuh, serta boleh membantu kami mencipta panduan permainan dengan lebih cepat dan cekap.

Perisian tengah rangka kerja Yii: menyediakan sokongan storan data berbilang untuk aplikasi Perisian tengah rangka kerja Yii: menyediakan sokongan storan data berbilang untuk aplikasi Jul 28, 2023 pm 12:43 PM

Perisian tengah rangka kerja Yii: menyediakan sokongan storan data berbilang untuk aplikasi Pengenalan Middleware (perisian tengah) ialah konsep penting dalam rangka kerja Yii, yang menyediakan sokongan storan data berbilang untuk aplikasi. Middleware bertindak seperti penapis, memasukkan kod tersuai antara permintaan dan respons aplikasi. Melalui perisian tengah, kami boleh memproses, mengesahkan, menapis permintaan, dan kemudian menyerahkan hasil yang diproses kepada perisian tengah atau pengendali akhir yang seterusnya. Middleware dalam rangka kerja Yii sangat mudah digunakan

Yii Framework Middleware: Tambahkan keupayaan pengelogan dan penyahpepijatan pada aplikasi anda Yii Framework Middleware: Tambahkan keupayaan pengelogan dan penyahpepijatan pada aplikasi anda Jul 28, 2023 pm 08:49 PM

Perisian tengah rangka kerja Yii: Tambah keupayaan pengelogan dan penyahpepijatan pada aplikasi [Pengenalan] Semasa membangunkan aplikasi web, biasanya kami perlu menambah beberapa ciri tambahan untuk meningkatkan prestasi dan kestabilan aplikasi. Rangka kerja Yii menyediakan konsep perisian tengah yang membolehkan kami melaksanakan beberapa tugas tambahan sebelum dan selepas aplikasi mengendalikan permintaan. Artikel ini akan memperkenalkan cara menggunakan fungsi perisian tengah bagi rangka kerja Yii untuk melaksanakan fungsi pengelogan dan penyahpepijatan. [Apakah middleware] Middleware merujuk kepada pemprosesan permintaan dan respons sebelum dan selepas aplikasi memproses permintaan.

Sulitkan dan nyahsulit data sensitif menggunakan perisian tengah rangka kerja Yii Sulitkan dan nyahsulit data sensitif menggunakan perisian tengah rangka kerja Yii Jul 28, 2023 pm 07:12 PM

Menyulitkan dan menyahsulit data sensitif menggunakan perisian tengah rangka kerja Yii Pengenalan: Dalam aplikasi Internet moden, privasi dan keselamatan data adalah isu yang sangat penting. Untuk memastikan bahawa data sensitif pengguna tidak boleh diakses oleh pelawat yang tidak dibenarkan, kami perlu menyulitkan data ini. Rangka kerja Yii memberikan kami cara yang mudah dan berkesan untuk melaksanakan fungsi menyulitkan dan menyahsulit data sensitif. Dalam artikel ini, kami akan membincangkan cara untuk mencapai ini menggunakan perisian tengah rangka kerja Yii. Pengenalan kepada rangka kerja Yii Rangka kerja Yii ialah rangka kerja PHP berprestasi tinggi.

Cara menggunakan pengawal untuk mengendalikan permintaan Ajax dalam rangka kerja Yii Cara menggunakan pengawal untuk mengendalikan permintaan Ajax dalam rangka kerja Yii Jul 28, 2023 pm 07:37 PM

Dalam rangka kerja Yii, pengawal memainkan peranan penting dalam memproses permintaan. Selain mengendalikan permintaan halaman biasa, pengawal juga boleh digunakan untuk mengendalikan permintaan Ajax. Artikel ini akan memperkenalkan cara mengendalikan permintaan Ajax dalam rangka kerja Yii dan memberikan contoh kod. Dalam rangka kerja Yii, pemprosesan permintaan Ajax boleh dijalankan melalui langkah-langkah berikut: Langkah pertama ialah mencipta kelas pengawal (Pengawal). Anda boleh mewarisi kelas pengawal asas yiiwebCo yang disediakan oleh rangka kerja Yii

See all articles