Rumah >pangkalan data >tutorial mysql >MySQL melaksanakan fungsi pengurusan hak pengguna sistem pesanan

MySQL melaksanakan fungsi pengurusan hak pengguna sistem pesanan

王林
王林asal
2023-11-01 18:30:241250semak imbas

MySQL 实现点餐系统的用户权限管理功能

MySQL melaksanakan fungsi pengurusan hak pengguna sistem pesanan makanan. Contoh kod khusus diperlukan

Tajuk: MySQL melaksanakan pengurusan hak pengguna. fungsi sistem pesanan makanan

Pengenalan:
Pengurusan hak pengguna ialah fungsi yang sangat penting dalam sistem Ia boleh mengawal hak akses pengguna kepada sumber yang berbeza dalam sistem dan memastikan keselamatan data dan kestabilan sistem. Artikel ini akan memperkenalkan cara menggunakan MySQL untuk melaksanakan fungsi pengurusan hak pengguna sistem pesanan dan memberikan contoh kod khusus.

Teks:

  1. Buat jadual pengguna dan jadual kebenaran:
    Pertama anda perlu mencipta dua jadual dalam MySQL, satu ialah jadual pengguna untuk Kedai maklumat seperti akaun log masuk pengguna dan kata laluan yang lain ialah jadual kebenaran, yang digunakan untuk menyimpan kebenaran akses pengguna kepada sumber yang berbeza.

Struktur jadual pengguna adalah seperti berikut:

BUAT JADUAL pengguna (user (
id INT(11) NOT NULL AUTO_INCREMENT,
username VARCHAR(50) NOT NULL,
password VARCHAR(50) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

权限表的结构如下:

CREATE TABLE permission (
id INT(11) NOT NULL AUTO_INCREMENT,
user_id INT(11) NOT NULL,
resource VARCHAR(50) NOT NULL,
PRIMARY KEY (id),
FOREIGN KEY (user_id) REFERENCES user(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

  1. 插入测试数据:
    接下来,插入一些测试数据,用于后续的权限管理功能测试。

插入用户数据的SQL语句如下:

INSERT INTO user (username, password)
VALUES ('user1', '123456'),

   ('user2', '123456'),
   ('user3', '123456');

插入权限数据的SQL语句如下:

INSERT INTO permission (user_id, resource)
VALUES (1, 'order'),

   (1, 'menu'),
   (2, 'menu'),
   (3, 'order');
  1. 实现用户登录功能:
    在点餐系统中,首先需要实现用户登录功能。用户登录时,需要验证用户输入的账号和密码是否正确。

以下是一个简单的用户登录的SQL查询语句示例:

SELECT *
FROM user
WHERE username = 'user1'
AND password = '123456';

如果查询结果为空,则表示账号或密码错误;如果查询结果非空,则表示账号密码验证通过,可以继续后续的操作。

  1. 实现权限验证功能:
    在用户登录验证通过之后,可以根据用户的权限对系统中的不同资源进行访问控制。

以下是一个简单的权限验证的SQL查询语句示例:

SELECT *
FROM permission
WHERE user_id = 1
AND resource id INT (11) NOT NULL AUTO_INCREMENT,

username VARCHAR(50) NOT NULL,

password VARCHAR(50) NOT NULL,# 🎜🎜# KUNCI UTAMA (id)

) ENGINE=CARSET LAALA InnoDB=utf8;

Struktur jadual kebenaran adalah seperti berikut:


CIPTA JADUAL kebenaran (

id INT(11) BUKAN NULL AUTO_INCREMENT,

id_pengguna INT(11 ) BUKAN NULL,

sumber VARCHAR(50) BUKAN NULL,

KUNCI UTAMA (id),

KUNCI ASING ( id_pengguna) RUJUKAN pengguna
(id)#🎜🎜#) ENGINE=CARSET LALAI InnoDB=utf8;#🎜🎜#
    #🎜🎜#Masukkan data ujian: #🎜🎜#Seterusnya, masukkan beberapa data ujian untuk ujian fungsi pengurusan kebenaran berikutnya. #🎜🎜##🎜🎜##🎜🎜#Pernyataan SQL untuk memasukkan data pengguna adalah seperti berikut: #🎜🎜##🎜🎜#INSERT IN TO user (username , kata laluan)#🎜🎜#VALUES ('user1', '123456'),#🎜🎜#rrreee#🎜🎜#Pernyataan SQL untuk memasukkan data kebenaran adalah seperti berikut: #🎜🎜## 🎜🎜#MASUKKAN KE DALAM kebenaran (id_pengguna, sumber)#🎜🎜#VALUES (1, 'pesanan'),#🎜🎜#rreee
      #🎜🎜# Laksanakan fungsi log masuk pengguna: #🎜🎜# Dalam sistem pesanan, anda perlu melaksanakan fungsi log masuk pengguna terlebih dahulu. Apabila pengguna log masuk, adalah perlu untuk mengesahkan sama ada nombor akaun dan kata laluan yang dimasukkan oleh pengguna adalah betul. #🎜🎜##🎜🎜##🎜🎜#Berikut ialah contoh pernyataan pertanyaan SQL mudah untuk log masuk pengguna: #🎜🎜##🎜🎜#SELECT *#🎜🎜#FROM pengguna #🎜 🎜#WHERE nama pengguna = 'pengguna1'#🎜🎜# DAN kata laluan = '123456';#🎜🎜##🎜🎜#Jika hasil pertanyaan kosong, ia bermakna nombor akaun Atau kata laluan salah; jika hasil pertanyaan tidak kosong, ini bermakna akaun dan kata laluan telah disahkan dan anda boleh meneruskan operasi berikutnya. #🎜🎜#
        #🎜🎜#Laksanakan fungsi pengesahan kebenaran: #🎜🎜#Selepas pengesahan log masuk pengguna diluluskan, kawalan akses boleh dilakukan pada sumber yang berbeza dalam sistem mengikut kebenaran pengguna . #🎜🎜##🎜🎜##🎜🎜#Berikut ialah contoh pertanyaan SQL pengesahan kebenaran mudah: #🎜🎜##🎜🎜#SELECT *#🎜🎜#FROM kebenaran#🎜 🎜#WHERE user_id = 1#🎜🎜# DAN resource = 'order';#🎜🎜##🎜🎜#Jika hasil pertanyaan kosong, ini bermakna pengguna tidak mempunyai hak untuk mengakses sumber yang ditentukan jika hasil pertanyaan tidak kosong, ini bermakna pengguna mempunyai hak untuk mengakses sumber yang ditentukan. #🎜🎜##🎜🎜#Anda boleh menggunakan pernyataan pertanyaan yang lebih kompleks untuk melaksanakan fungsi pengesahan kebenaran yang lebih kaya mengikut keperluan sebenar, seperti menggunakan pertanyaan sambungan untuk mendapatkan senarai kebenaran khusus pengguna. #🎜🎜##🎜🎜#Ringkasan: #🎜🎜#Melalui langkah di atas, kita boleh menggunakan MySQL untuk melaksanakan fungsi pengurusan hak pengguna sistem pesanan. Apabila pengguna log masuk, dia boleh mengesahkan ketepatan akaun dan kata laluan, dan selepas pengesahan berjaya, akses kepada sumber yang berbeza dalam sistem boleh dikawal berdasarkan kebenaran pengguna. #🎜🎜##🎜🎜#Sudah tentu, contoh kod di atas hanyalah demonstrasi mudah, dan fungsi pengurusan kebenaran sebenar mungkin lebih kompleks. Dalam pembangunan sebenar, butiran lanjut dan isu keselamatan perlu dipertimbangkan, seperti storan disulitkan kata laluan, menghalang suntikan SQL, dsb. #🎜🎜##🎜🎜# Saya harap pengenalan dalam artikel ini dapat membantu anda dalam memahami dan melaksanakan fungsi pengurusan hak pengguna. #🎜🎜#

Atas ialah kandungan terperinci MySQL melaksanakan fungsi pengurusan hak pengguna sistem pesanan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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