PHP dan UniApp melaksanakan kawalan kebenaran data dan sekatan akses
Apabila membangunkan aplikasi web atau aplikasi mudah alih, selalunya perlu untuk melaksanakan kawalan kebenaran dan sekatan akses pada data untuk memastikan keselamatan dan privasi data. Artikel ini akan memperkenalkan cara menggunakan rangka kerja PHP dan UniApp untuk melaksanakan kawalan kebenaran data dan sekatan akses, serta memberikan contoh kod yang sepadan.
1. PHP melaksanakan kawalan kebenaran data
BUAT JADUAL user
(
id
int(11) NOT NULL AUTO_INCREMENT,
username
varchar(255) NOT NULL,
password
varchar(255) NOT NULL,
role
varchar(255) NOT NULL,
PRIMARY KEY (id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
在该表中,我们可以存储用户的登录名、密码和角色信息。角色信息可以用来表示用户的权限级别,比如普通用户、管理员等。
CREATE TABLE table_permission
(
id
int(11) NOT NULL AUTO_INCREMENT,
user_id
int(11) NOT NULL,
table_name
varchar(255) NOT NULL,
read_permission
tinyint(1) NOT NULL,
write_permission
tinyint(1) NOT NULL,
PRIMARY KEY (id
password
varchar(255) NOT NULL, role
varchar(255) NOT NULL,
id code>)<ol start="3">) ENGINE=InnoDB DEFAULT CHARSET=utf8;<li>
<br>Dalam jadual ini, kita boleh menyimpan nama log masuk pengguna, kata laluan dan maklumat peranan. Maklumat peranan boleh digunakan untuk menunjukkan tahap kuasa pengguna, seperti pengguna biasa, pentadbir, dsb. </li>
</ol>
<p>Pengurusan kebenaran jadual data</p>Seterusnya, kita perlu mereka bentuk jadual kebenaran yang sepadan untuk setiap jadual data untuk mengurus kebenaran akses pengguna kepada jadual data. Berikut ialah contoh struktur jadual kebenaran mudah: <p><br><br>BUAT JADUAL <kod>kebenaran_jadual</kod></p>
( id
int(11) BUKAN NULL AUTO_INCREMENT, user_id
int(11) NOT NULL,
table_name
varchar(255) NOT NULL,
read_permission
tinyint(1) NOT NULL,
write_permission code> tinyint (1) NOT NULL,<p> PRIMARY KEY (<code>id
)Dalam jadual ini, kita boleh menyimpan ID pengguna, nama jadual data dan nama pengguna jadual data kebenaran membaca dan menulis. Dengan menanyakan jadual ini, kita boleh menentukan sama ada pengguna telah membaca dan menulis kebenaran ke jadual data tertentu.
Melaksanakan kawalan kebenaran
Berikut ialah contoh fungsi penghakiman kebenaran mudah:
$result = mysqli_query($connection, "SELECT * FROM table_permission WHERE user_id = $user_id AND table_name = '$table_name'");
$row = mysqli_fetch_assoc($result_assoc ;
// Tentukan sama ada kebenaran pengguna memenuhi keperluan
return true;
return false;
}
uni.request({
kaedah: 'GET',
pengepala: {
'Authorization': 'Bearer ' + token // 这里需要传递用户的登录凭证
},
kejayaan : function (res) {
if (res.statusCode === 200) { // 处理获取到的权限信息 uni.setStorageSync('permission', res.data.permission); }
}
});Dalam contoh ini, kami memperoleh maklumat kebenaran pengguna dengan menghantar permintaan GET ke antara muka API pelayan dan menyimpannya secara setempat. 🎜Kawalan kebenaran bahagian hadapan🎜Dalam UniApp, kami boleh mengawal akses pengguna kepada data dengan membuat pertimbangan kebenaran pada halaman atau komponen. Berikut ialah contoh mudah: 🎜🎜🎜eksport lalai {🎜 data() {🎜return { permission: uni.getStorageSync('permission') }
checkPermission() { if (this.permission.read_permission && this.permission.write_permission) { // 执行需要控制权限的操作 } else { // 显示没有权限的提示信息 } }
Atas ialah kandungan terperinci PHP dan UniApp melaksanakan kawalan kebenaran data dan sekatan akses. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!