


Melaksanakan kebenaran pengguna dan kawalan akses menggunakan PHP dan SQLite
Kebenaran pengguna dan kawalan akses menggunakan PHP dan SQLite
Dalam aplikasi web moden, kebenaran pengguna dan kawalan akses adalah bahagian yang sangat penting. Dengan pengurusan kebenaran yang betul, anda boleh memastikan bahawa hanya pengguna yang diberi kuasa boleh mengakses halaman dan fungsi tertentu. Dalam artikel ini, kita akan belajar cara melaksanakan kebenaran pengguna asas dan kawalan akses menggunakan PHP dan SQLite.
Pertama, kita perlu mencipta pangkalan data SQLite untuk menyimpan maklumat tentang pengguna dan kebenaran mereka. Berikut ialah struktur jadual pengguna ringkas dan jadual kebenaran:
CREATE TABLE users ( id INTEGER PRIMARY KEY, username TEXT, password TEXT ); CREATE TABLE permissions ( id INTEGER PRIMARY KEY, name TEXT, description TEXT ); CREATE TABLE user_permissions ( user_id INTEGER, permission_id INTEGER, FOREIGN KEY (user_id) REFERENCES users(id), FOREIGN KEY (permission_id) REFERENCES permissions(id) );
Dalam contoh ini, kami telah mencipta tiga jadual. Jadual pengguna
menyimpan maklumat asas pengguna, termasuk id, nama pengguna dan kata laluan. Jadual permissions
menyimpan semua kebenaran yang tersedia Setiap kebenaran mempunyai id, nama dan perihalan. Jadual user_permissions
ialah jadual hubungan yang mengaitkan pengguna dengan kebenaran mereka. Jadual menggunakan user_id dan permission_id sebagai kunci asing. users
表存储用户的基本信息,包括id、username和password。permissions
表存储所有可用的权限,每个权限都有id、name和description。user_permissions
表是一个关联表,用于将用户和他们的权限关联起来。该表使用user_id和permission_id作为外键。
接下来,我们可以使用PHP代码来实现用户注册、登录和权限检查的功能。以下是示例代码的简化版本:
<?php class User { private $db; public function __construct() { $this->db = new SQLite3('path/to/database.db'); } public function register($username, $password) { // 检查用户名是否已经存在 if ($this->getUserByUsername($username)) { return false; } // 生成密码哈希 $hashedPassword = password_hash($password, PASSWORD_DEFAULT); // 插入新用户到数据库 $stmt = $this->db->prepare('INSERT INTO users (username, password) VALUES (:username, :password)'); $stmt->bindParam(':username', $username); $stmt->bindParam(':password', $hashedPassword); $stmt->execute(); return true; } public function login($username, $password) { // 获取用户信息 $user = $this->getUserByUsername($username); // 验证密码 if ($user && password_verify($password, $user['password'])) { // 存储用户信息到会话 $_SESSION['user'] = $user; return true; } return false; } public function isLoggedIn() { return isset($_SESSION['user']); } public function hasPermission($permission) { if (!$this->isLoggedIn()) { return false; } // 检查用户权限 $stmt = $this->db->prepare('SELECT COUNT(*) FROM user_permissions WHERE user_id = :user_id AND permission_id = :permission_id'); $stmt->bindParam(':user_id', $_SESSION['user']['id']); $stmt->bindParam(':permission_id', $permission); $result = $stmt->execute()->fetchArray(); return $result[0] > 0; } private function getUserByUsername($username) { $stmt = $this->db->prepare('SELECT * FROM users WHERE username = :username'); $stmt->bindParam(':username', $username); $result = $stmt->execute()->fetchArray(); return $result ? $result : false; } } ?>
以上代码是一个简单的User类,它提供了注册、登录和权限检查的功能。在构造函数中,我们连接到了SQLite数据库。register
方法用于用户注册,它检查用户名是否已经存在,然后将新用户插入到数据库。login
方法用于用户登录,它验证密码并将用户信息存储在会话中。isLoggedIn
方法检查用户是否已经登录,hasPermission
<?php // 实例化User类 $user = new User(); // 用户注册 $user->register('alice', 'password'); // 用户登录 $user->login('alice', 'password'); // 检查用户权限 if ($user->hasPermission(1)) { echo 'User has permission!'; } else { echo 'Access denied!'; } ?>
register
digunakan untuk pendaftaran pengguna Ia menyemak sama ada nama pengguna sudah wujud dan kemudian memasukkan pengguna baharu ke dalam pangkalan data. Kaedah login
digunakan untuk log masuk pengguna, ia mengesahkan kata laluan dan menyimpan maklumat pengguna dalam sesi. Kaedah isLoggedIn
menyemak sama ada pengguna telah log masuk dan kaedah hasPermission
menyemak sama ada pengguna mempunyai kebenaran khusus. Contoh Penggunaan: rrreee
Dalam contoh di atas, kami mula-mula membuat instantiate kelas Pengguna. Kami kemudian mendaftarkan pengguna baharu dan log masuk menggunakan pengguna tersebut. Akhir sekali, kami menyemak sama ada pengguna mempunyai kebenaran 1 dan mengeluarkan mesej yang sesuai berdasarkan hasilnya. 🎜🎜Dengan menggunakan PHP dan SQLite, kami boleh melaksanakan kebenaran pengguna dan fungsi kawalan akses dengan sangat mudah. Contoh ini hanyalah pelaksanaan asas Anda boleh membuat beberapa pelanjutan dan penambahbaikan mengikut keperluan anda sendiri, seperti menambah pengurusan kebenaran dan kawalan peranan yang lebih lanjut. Harap artikel ini membantu anda! 🎜Atas ialah kandungan terperinci Melaksanakan kebenaran pengguna dan kawalan akses menggunakan PHP dan SQLite. 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

Dalam bab ini, kita akan memahami Pembolehubah Persekitaran, Konfigurasi Umum, Konfigurasi Pangkalan Data dan Konfigurasi E-mel dalam CakePHP.

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

Dalam bab ini, kita akan mempelajari topik berikut yang berkaitan dengan penghalaan ?

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.
