当前位置: 首页 > news >正文

柳州网站推广哪家好玉林网站seo

柳州网站推广哪家好,玉林网站seo,衡水注册公司流程和费用,静态网页设计模板免费【用户管理与权限 - 篇六】前端动态展现:基于权限的菜单与按钮控制 前言实现思路整体架构技术方案第一部分:后端权限接口增强1. 自定义 TokenObtainPairSerializer2. 更新 URL 配置第二部分:前端用户状态管理1. 更新用户 Store第三部分:路由权限配置1. 为路由添加权限元信息…

【用户管理与权限 - 篇六】前端动态展现:基于权限的菜单与按钮控制

    • 前言
    • 实现思路
      • 整体架构
      • 技术方案
    • 第一部分:后端权限接口增强
      • 1. 自定义 TokenObtainPairSerializer
      • 2. 更新 URL 配置
    • 第二部分:前端用户状态管理
      • 1. 更新用户 Store
    • 第三部分:路由权限配置
      • 1. 为路由添加权限元信息
    • 第四部分:动态菜单实现
      • 1. 重构布局组件
    • 第五部分:页面按钮权限控制
      • 1. 项目列表页面示例
      • 2. 通用权限控制模式
    • 第六部分:测试验证
      • 1. 创建测试用户
      • 2. 验证测试流程
    • 总结
      • ✅ 实现的功能
      • 🔧 技术特点

前言

在前面的系列文章中,我们已经成功构建了用户、角色和权限的后端模型与API,并实现了前端的用户管理、角色管理以及为角色分配权限的界面。但是,仅仅在后端做权限关联还不够,前端的展现也需要根据用户的权限进行调整。

理想的用户体验应该是:

  • 用户登录后,侧边栏菜单只显示他们有权限访问的模块
  • 在各个页面中,只有具备相应操作权限的用户才能看到对应的操作按钮
  • 无权限的用户不会看到他们无法操作的功能,避免点击后被拒绝的尴尬体验

本文将带你完整实现这套前端权限控制系统,让权限配置真正发挥作用。

实现思路

整体架构

  1. 后端增强:登录接口返回用户权限编码列表
  2. 前端存储:Pinia store 管理用户权限状态
  3. 动态菜单:根据权限动态生成侧边栏菜单
  4. 按钮控制:页面中的操作按钮根据权限显示/隐藏
  5. 路由守卫:在路由层面也进行权限验证

技术方案

  • 使用 JWT Token 携带基础用户信息
  • 登录响应中附加完整的权限编码列表
  • 前端使用 v-if 指令进行条件渲染
  • 创建全局权限检查方法 hasPermission()

第一部分:后端权限接口增强

1. 自定义 TokenObtainPairSerializer

首先修改后端登录接口,使其返回用户的权限信息。

api/serializers.py 中添加自定义序列化器:
在这里插入图片描述

# api/serializers.py
from rest_framework_simplejwt.serializers import TokenObtainPairSerializer
from typing import Setclass MyTokenObtainPairSerializer(TokenObtainPairSerializer):@classmethoddef get_token(cls, user):token = super().get_token(user)  # 调用父类方法获取基础 token# 添加自定义声明到 token 的 payload 中token['username'] = user.username# 如果用户是超级用户,则在token中标记if user.is_superuser:token['is_superuser'] = Truereturn tokendef validate(self, attrs):data = super().validate(attrs)  # 调用父类 validate 获取 access 和 refresh token# 添加用户权限编码列表到返回数据中user_permissions: Set[str] = set()# self.user 是通过父类 validate 认证成功后的用户对象if hasattr(self.user, 'profile') and self.user.profile is not None:for role in self.user.profile.roles.prefetch_related('permissions').all():for perm in role.permissions.all():user_permissions.add(perm.code)if self.user.is_superuser:data['is_superuser'] = True  # 标记超级用户# 超管拥有所有权限from .models import Permissionall_permissions = Permission.objects.values_list('code', flat=True)data['permissions'] = list(all_permissions)else:data['is_superuser'] = Falsedata['permissions'] = list(user_permissions)data['username'] = self.user.usernamedata['user_id'] = self.user.idreturn data

关键实现点:

  • 继承 TokenObtainPairSerializer 并重写 validate 方法
  • 通过用户的 profile -> roles -> permissions 关系链获取所有权限编码
  • 使用 set() 去重,确保权限编码唯一
  • 超级管理员自动获得所有权限
  • 使用 prefetch_related('permissions') 优化数据库查询

2. 更新 URL 配置

修改 backend/urls.py,使用自定义的登录视图:
在这里插入图片描述

# backend/urls.py
from django.contrib import admin
from django.urls import path, include
from rest_framework_simplejwt.views import (TokenRefreshView,TokenVerifyView,
)
from rest_framework_simplejwt.views import TokenObtainPairView as BaseTokenObtainPairView
from api.serializers import MyTokenObtainPairSerializer# 创建一个使用自定义 Serializer 的视图
class MyTokenObtainPairView(BaseTokenObtainPairView):serializer_class = MyTokenObtainPairSerializerurlpatterns = [path('admin/', admin.site.urls),path('api/', include('api.urls')),# 使用自定义的 TokenObtainPairViewpath('api/token/', MyTokenObtainPairView.as_view(), name='token_obtain_pair'),path('api/token/refresh/', TokenRefreshView.as_view(), name='token_refresh'),path('api/token/verify/', TokenVerifyView.as_view(), name='token_verify'),
]

现在登录接口的响应格式如下:
在这里插入图片描述

第二部分:前端用户状态管理

1. 更新用户 Store

修改 frontend/src/stores/user.ts,增加权限管理功能:
在这里插入图片描述

// frontend/src/stores/user.ts
import { defineStore } from 'pinia'
import { ElMessage } from 'element-plus'
import router from '@/router'
import request from '@/utils/request'
import type { AxiosError } from 'axios'// 更新后端登录接口的响应类型
interface LoginResponse {access: string;refresh: string;username: string;user_id: number;permissions: string[]; // 权限编码列表is_superuser: boolean; // 是否为超级用户
}// 更新用户信息的接口类型
interface UserState {accessToken: string | null;refreshToken: string | null;username: string | null;userId: number | null;permissions: string[]; // 存储用户权限编码isSuperuser: boolean;  // 存储是否为超级用户
}export const useUserStore = defineStore('user', {state: (): UserState => ({accessToken: localStorage.getItem('access-token') || null,refreshToken: localStorage.getItem('refresh-token') || null,username: localStorage.getItem('username') || null,userId: localStorage.getItem('user-id') ? Number(localStorage.getItem<
http://www.khdw.cn/news/60431.html

相关文章:

  • 如何在国外做网站推广品牌
  • 怎么发布个人网站如何用手机制作网站
  • 博罗做网站哪家强游戏推广员是诈骗吗
  • 云阳网站建设厦门seo厦门起梦
  • 济南轻电商网站建设公司上海快速优化排名
  • 义乌网站制作是什么深圳网站制作哪家好
  • iis 网站制作荆门今日头条新闻发布
  • 加强政府网站信息建设工作通知专业海外网站推广
  • 网站建设合同福州短视频seo获客
  • 学生做的网站东莞网络公司电话
  • 网站做等保测评百度联盟官网
  • 网站制作公司需要什么资质google推广妙招
  • 如何做医疗网站的专题页淘宝关键词排名怎么查询
  • 微网站建设包括哪些方面技能培训有哪些科目
  • 网站建设者属于广告经营者吗5118大数据平台官网
  • 江苏外贸网站建设推广seo和sem的区别是什么
  • 重庆做网站_重庆网站建设_重庆网络推广_重庆网络公司黄页推广引流
  • 工程类招聘网站哪个好seoul怎么读
  • 广州网站开发技术腾讯企业邮箱登录入口
  • 广州网站建设系统开发seo网上课程
  • 广东一站式网站建设报价杭州seo培训
  • 站设计培训课程百度图片识别搜索
  • 示范校建设平台网站典型案例市场营销在线课程
  • 网站上线推广什么是seo优化推广
  • 个人网站可以做商业吗济南seo网站优化
  • 哪有做网站的青岛网站推广公司
  • wordpress设置网站关键词排名seo
  • 做网站的目标是什么seo优化的作用
  • b站怎么看视频分区长沙网站seo优化
  • 谈谈网站的开发流程新浪网今日乌鲁木齐新闻