


Comment implémenter la gestion des droits des utilisateurs avec PHP et UniApp
Comment PHP et UniApp implémentent la gestion des droits des utilisateurs
Dans le développement Web, la gestion des droits des utilisateurs est une fonction très importante. Il peut contrôler les droits d'accès des utilisateurs à différentes fonctions et ressources du système et garantir la sécurité et l'intégrité du système. Cet article présentera comment utiliser PHP et UniApp pour implémenter la gestion des droits des utilisateurs et sera accompagné d'exemples de code correspondants.
1. Conception de la base de données
Avant de commencer, nous devons d'abord concevoir une base de données pour stocker les informations relatives aux utilisateurs et aux autorisations. Ce qui suit est une conception de base de données simple :
- Table utilisateur (utilisateur) : utilisée pour stocker les informations de base des utilisateurs, notamment l'ID utilisateur, le nom d'utilisateur, le mot de passe, etc.
- Table des rôles (role) : utilisée pour stocker les informations sur le rôle, y compris l'ID du rôle, le nom du rôle, etc.
- Table d'autorisation (autorisation) : utilisée pour stocker les informations d'autorisation des fonctions et des ressources du système, y compris l'ID d'autorisation, le nom de l'autorisation, etc.
- Table d'association des rôles utilisateur (user_role) : utilisée pour établir l'association entre les utilisateurs et les rôles.
- Table d'association des autorisations de rôle (role_permission) : utilisée pour établir l'association entre les rôles et les autorisations.
2. Implémentation du backend PHP
- Vérification de la connexion utilisateur
Lorsqu'un utilisateur se connecte, nous devons vérifier si son nom d'utilisateur et son mot de passe sont corrects. Voici un exemple simple de code de vérification de connexion :
<?php // 获取用户提交的用户名和密码 $username = $_POST['username']; $password = $_POST['password']; // 查询数据库验证用户信息 $query = "SELECT * FROM user WHERE username='$username' AND password='$password'"; $result = mysqli_query($connection, $query); // 如果查询结果有一条记录,则登录成功;否则登录失败 if (mysqli_num_rows($result) == 1) { // 登录成功,生成并返回一个token给客户端 $token = generateToken($username); echo json_encode(['status' => 'success', 'token' => $token]); } else { // 登录失败 echo json_encode(['status' => 'failed', 'message' => 'Invalid username or password']); } ?>
- Vérification des autorisations utilisateur
Lors de la vérification des autorisations utilisateur, nous devons trouver les autorisations correspondantes en fonction du rôle de l'utilisateur. Voici un exemple simple de code de vérification des autorisations :
<?php // 获取用户提交的token和权限id $token = $_POST['token']; $permissionId = $_POST['permissionId']; // 验证token是否有效 if (validateToken($token)) { // 查询用户对应的角色 $query = "SELECT role_id FROM user_role WHERE user_id='$userId'"; $result = mysqli_query($connection, $query); $roleIds = mysqli_fetch_all($result, MYSQLI_ASSOC); // 查询角色对应的权限 $query = "SELECT * FROM role_permission WHERE role_id IN (" . implode(',', $roleIds) . ")"; $result = mysqli_query($connection, $query); $permissions = mysqli_fetch_all($result, MYSQLI_ASSOC); // 验证用户是否具有该权限 $hasPermission = false; foreach ($permissions as $permission) { if ($permission['permission_id'] == $permissionId) { $hasPermission = true; break; } } // 返回验证结果给客户端 echo json_encode(['hasPermission' => $hasPermission]); } else { // token无效 echo json_encode(['hasPermission' => false]); } ?>
3. Implémentation frontale d'UniApp
- Page de connexion de l'utilisateur
Sur la page de connexion de l'utilisateur, nous devons envoyer le nom d'utilisateur et le mot de passe saisis par l'utilisateur au backend pour vérification et obtenir le jeton retourné. Voici un exemple simple de code de page de connexion :
<template> <view> <input v-model="username" type="text" placeholder="Username" /> <input v-model="password" type="password" placeholder="Password" /> <button @click="login">Login</button> </view> </template> <script> export default { data() { return { username: '', password: '' } }, methods: { login() { // 发送登录请求给后端 uni.request({ url: '/api/login.php', method: 'POST', data: { username: this.username, password: this.password }, success: (res) => { if (res.data.status === 'success') { // 登录成功,保存token到本地 uni.setStorageSync('token', res.data.token); uni.navigateTo({ url: '/pages/home/home' }); } else { // 登录失败,提示错误信息 uni.showToast({ title: res.data.message, icon: 'none' }); } } }); } } } </script>
- Vérification des autorisations
Sur la page qui doit vérifier les autorisations de l'utilisateur, nous devons envoyer le jeton et l'ID d'autorisation de l'utilisateur au backend pour vérification. Voici un exemple simple de code de vérification des autorisations :
export default { data() { return { hasPermission: false } }, mounted() { // 发送权限验证请求给后端 uni.request({ url: '/api/validatePermission.php', method: 'POST', data: { token: uni.getStorageSync('token'), permissionId: 1 // 需要验证的权限ID }, success: (res) => { this.hasPermission = res.data.hasPermission; } }); } }
Grâce à la méthode ci-dessus, nous pouvons implémenter des fonctions de gestion des autorisations des utilisateurs basées sur PHP et UniApp. Lorsqu'un utilisateur se connecte, nous vérifions son nom d'utilisateur et son mot de passe et générons un jeton à retourner au client. Le client enregistre le jeton localement et l'envoie au backend pour vérification lorsque des autorisations de vérification sont requises. Le backend recherche le rôle et les autorisations correspondant à l'utilisateur en fonction du jeton et renvoie les résultats de la vérification des autorisations au client.
J'espère que cet article pourra vous aider à comprendre comment PHP et UniApp implémentent la gestion des droits des utilisateurs. Bien entendu, les projets réels peuvent présenter des exigences plus complexes, mais l’idée de base est la même. Tant que nous suivons une bonne conception de base de données et une logique de code raisonnable, nous pouvons mettre en œuvre un système de gestion des droits des utilisateurs sûr et fiable.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.
