Heim > Datenbank > MySQL-Tutorial > So erstellen Sie mit MySQL Berechtigungstabellen zur Implementierung von Berechtigungsverwaltungsfunktionen

So erstellen Sie mit MySQL Berechtigungstabellen zur Implementierung von Berechtigungsverwaltungsfunktionen

WBOY
Freigeben: 2023-07-01 22:55:38
Original
1537 Leute haben es durchsucht

So erstellen Sie mit MySQL Berechtigungstabellen zur Implementierung von Berechtigungsverwaltungsfunktionen

Übersicht:
Berechtigungsverwaltung ist ein unverzichtbarer Bestandteil der modernen Anwendungsentwicklung. Durch die Berechtigungsverwaltung können wir den Zugriff und die Vorgänge von Benutzern auf Systemressourcen einschränken. In diesem Artikel wird erläutert, wie Sie mithilfe von MySQL eine Berechtigungstabelle zum Implementieren von Berechtigungsverwaltungsfunktionen erstellen und entsprechende Codebeispiele bereitstellen.

Schritt 1: Benutzertabelle erstellen
Zuerst müssen wir eine Benutzertabelle erstellen, um Benutzerinformationen des Systems zu speichern. Mit dem folgenden Codebeispiel können Sie eine Benutzertabelle mit dem Namen „Benutzer“ erstellen:

CREATE TABLE users (
  id INT AUTO_INCREMENT PRIMARY KEY,
  username VARCHAR(255) NOT NULL,
  password VARCHAR(255) NOT NULL,
  enabled BOOLEAN NOT NULL
);
Nach dem Login kopieren

Die Benutzertabellenstruktur umfasst Felder wie Benutzer-ID (ID), Benutzername (Benutzername), Kennwort (Passwort) und ob sie aktiviert (enabled) ist. .

Schritt 2: Erstellen Sie eine Berechtigungstabelle
Als nächstes müssen wir eine Berechtigungstabelle erstellen, um die Zugriffsberechtigungen für verschiedene Ressourcen im System zu speichern. Mit dem folgenden Codebeispiel können Sie eine Berechtigungstabelle mit dem Namen „permissions“ erstellen:

CREATE TABLE permissions (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(255) NOT NULL,
  description VARCHAR(255) NOT NULL
);
Nach dem Login kopieren

Die Berechtigungstabellenstruktur umfasst Felder wie Berechtigungs-ID (id), Berechtigungsname (name) und Berechtigungsbeschreibung (description).

Schritt 3: Erstellen Sie eine Benutzerberechtigungstabelle
Um Benutzern Berechtigungen zuzuordnen, müssen wir auch eine Benutzerberechtigungstabelle erstellen. Eine Benutzerberechtigungstabelle mit dem Namen „user_permissions“ kann durch das folgende Codebeispiel erstellt werden:

CREATE TABLE user_permissions (
  id INT AUTO_INCREMENT PRIMARY KEY,
  user_id INT NOT NULL,
  permission_id INT NOT NULL,
  FOREIGN KEY (user_id) REFERENCES users(id),
  FOREIGN KEY (permission_id) REFERENCES permissions(id)
);
Nach dem Login kopieren

Die Struktur der Benutzerberechtigungstabelle umfasst Felder wie Benutzerberechtigungs-ID (id), Benutzer-ID (user_id) und Berechtigungs-ID (permission_id) und bis Fremdschlüssel Bezogen auf Benutzertabelle und Berechtigungstabelle.

Schritt 4: Anfangsdaten einfügen
Zur Vereinfachung der Demonstration können wir einige Anfangsdaten in die Benutzertabelle und die Berechtigungstabelle einfügen. Das Folgende ist ein Codebeispiel zum Einfügen von Anfangsdaten:

INSERT INTO users (username, password, enabled)
VALUES ('admin', 'password', true);

INSERT INTO permissions (name, description)
VALUES ('create', 'Create resources'),
       ('read', 'Read resources'),
       ('update', 'Update resources'),
       ('delete', 'Delete resources');

INSERT INTO user_permissions (user_id, permission_id)
VALUES (1, 1),
       (1, 2),
       (1, 3),
       (1, 4);
Nach dem Login kopieren

Der obige Beispielcode fügt einen Benutzer namens „admin“ in die Benutzertabelle ein, setzt das Passwort auf „password“ und aktiviert es. Gleichzeitig werden vier Berechtigungen in die Berechtigungstabelle eingefügt, nämlich die Berechtigungen zum Erstellen von Ressourcen, zum Lesen von Ressourcen, zum Aktualisieren von Ressourcen und zum Löschen von Ressourcen. Ordnen Sie schließlich dem Benutzer „admin“ diese vier Berechtigungen zu.

Schritt 5: Benutzerberechtigungen abfragen
Jetzt können wir die Berechtigungsliste des angegebenen Benutzers abfragen, indem wir die Benutzerberechtigungstabelle abfragen. Das Folgende ist ein Codebeispiel zum Abfragen der Benutzerberechtigungsliste:

SELECT p.name
FROM users u
JOIN user_permissions up ON u.id = up.user_id
JOIN permissions p ON up.permission_id = p.id
WHERE u.username = 'admin';
Nach dem Login kopieren

Dieser Beispielcode fragt die Berechtigungsliste des Benutzers „admin“ ab, indem er die Benutzertabelle, die Benutzerberechtigungstabelle und die Berechtigungstabelle verbindet. Das Ergebnis gibt die Berechtigungsnamen zurück, über die der Benutzer verfügt.

Fazit:
Durch die oben genannten Schritte haben wir mit MySQL erfolgreich die Benutzertabelle, die Berechtigungstabelle und die Benutzerberechtigungstabelle erstellt und die Zuordnung zwischen Benutzern und Berechtigungen erreicht. Durch Abfragen der Benutzerberechtigungsliste können wir Benutzerzugriffsberechtigungen einfach verwalten. In tatsächlichen Anwendungen kann die Berechtigungsverwaltungsfunktion des Systems bei Bedarf weiter verbessert werden.

Alles in allem ist es eine einfache und effektive Möglichkeit, Berechtigungsverwaltungsfunktionen durch die Erstellung von Berechtigungstabellen zu implementieren. Mit dieser Methode können Benutzerzugriffsrechte einfach verwaltet und mit anderen Systemkomponenten (z. B. Benutzertabellen) verknüpft werden, um die Sicherheit und Wartbarkeit des Systems zu verbessern. Ich hoffe, dass die Einführung in diesem Artikel den Lesern im Hinblick auf die Berechtigungsverwaltung hilfreich sein wird.

Das obige ist der detaillierte Inhalt vonSo erstellen Sie mit MySQL Berechtigungstabellen zur Implementierung von Berechtigungsverwaltungsfunktionen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage