Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

A WinJS plugin that provides permission control for page resources.

License

NotificationsYou must be signed in to change notification settings

winjs-dev/winjs-plugin-access

Repository files navigation

适配 access(权限)的 WinJS 插件,适用于 Vue3。

npm versionlicensedownloads

功能特性

  • 🔐 基于角色的权限管理系统 (RBAC)
  • 🚀 支持动态设置角色和权限
  • 🛡️ 提供路由级别的权限控制
  • 🎯 提供组件级别的权限控制(指令和组件)
  • ⚡ 支持同步和异步权限检查
  • 🔍 支持路径模式匹配(支持通配符)
  • 📦 开箱即用,零配置启动
  • 🔧 可配置的权限控制处理器

安装

npm install @winner-fed/plugin-access

基本配置

.winrc.ts 中配置插件:

import{defineConfig}from'win';exportdefaultdefineConfig({plugins:[require.resolve('@winner-fed/plugin-access')],access:{roles:{admin:['/','/admin','/users/*'],normal:['/normal','/profile'],guest:['/login','/register']}}});

使用方法

1. 路由配置

// src/app.tsimport{accessasaccessApi}from'winjs';// 设置默认角色accessApi.setRole('admin');exportconstaccess={noFoundHandler({ next}){// 处理404页面constaccessIds=accessApi.getAccess();if(!accessIds.includes('/404')){accessApi.setAccess(accessIds.concat(['/404']));}next('/404');},unAccessHandler({ next}){// 处理无权限访问next('/403');},ignoreAccess:['/login','/register']// 忽略权限检查的路由};

2. 组件中使用

使用 v-access 指令

<template>  <div><!-- 只有有权限的用户才能看到-->    <divv-access="'/admin'">管理员内容</div><!-- 支持动态权限-->    <divv-access="dynamicPath">动态内容</div><!-- 支持通配符-->    <divv-access="'/users/*'">用户管理</div>  </div></template><script setup>import {ref }from'vue';constdynamicPath=ref('/profile');</script>

使用 Access 组件

<template>  <div>    <Accessid="/admin">      <template #default>        <div>管理员专用功能</div>      </template>    </Access>  </div></template>

使用 useAccess Hook

<template>  <div>    <divv-if="hasAdminAccess">管理员功能</div>    <divv-if="hasUserAccess">用户功能</div>  </div></template><script setup>import {useAccess }from'winjs';consthasAdminAccess=useAccess('/admin');consthasUserAccess=useAccess('/users/*');</script>

3. 编程式权限控制

import{access}from'winjs';// 设置角色access.setRole('admin');// 设置权限access.setAccess(['/admin','/users']);// 检查权限(异步)consthasAccess=awaitaccess.hasAccess('/admin');// 检查权限(同步)consthasAccessSync=access.hasAccessSync('/admin');// 获取当前角色constcurrentRole=access.getRole();// 获取当前权限列表constcurrentAccess=access.getAccess();// 路径匹配constisMatch=access.match('/users/profile',['/users/*']);// 设置预设权限access.setPresetAccess(['/public','/common']);

API 文档

配置项

access.roles

  • 类型:Record<string, string[]>
  • 描述:角色与权限的映射关系

access.noFoundHandler

  • 类型:(params: { router, to, from, next }) => void
  • 描述:404页面处理函数

access.unAccessHandler

  • 类型:(params: { router, to, from, next }) => void
  • 描述:无权限访问处理函数

access.ignoreAccess

  • 类型:string[]
  • 描述:忽略权限检查的路由列表

Access 对象方法

setRole(roleId: string | Promise)

设置当前用户角色。

getRole(): string

获取当前用户角色。

setAccess(accessIds: string[] | Promise<string[]>)

设置当前用户权限列表。

getAccess(): string[]

获取当前用户权限列表。

hasAccess(path: string): Promise

异步检查是否有指定路径的权限。

hasAccessSync(path: string): boolean

同步检查是否有指定路径的权限。

match(path: string, accessIds: string[]): boolean

检查路径是否匹配权限列表。

setPresetAccess(accessIds: string | string[])

设置预设权限。

isDataReady(): boolean

检查权限数据是否准备就绪。

useAccess Hook

consthasAccess=useAccess(path:string|Ref<string>):Ref<boolean>

返回一个响应式的权限状态。

高级用法

1. 异步权限设置

import{access}from'winjs';// 异步设置角色access.setRole(fetch('/api/user/role').then(res=>res.json()));// 异步设置权限access.setAccess(fetch('/api/user/permissions').then(res=>res.json()));

2. 动态权限更新

import{access}from'winjs';// 用户登录后更新权限functiononLogin(userInfo){access.setRole(userInfo.role);access.setAccess(userInfo.permissions);}// 用户登出后清空权限functiononLogout(){access.setRole('guest');access.setAccess([]);}

3. 权限通配符

支持以下通配符模式:

  • /users/* - 匹配/users/ 下的所有路径
  • /admin/*/edit - 匹配/admin/任意内容/edit 格式的路径

4. 权限组合

// 预设权限 + 角色权限 + 动态权限access.setPresetAccess(['/public','/common']);access.setRole('admin');// 自动获取 admin 对应的权限access.setAccess(['/special']);// 额外的动态权限

许可证

MIT.

About

A WinJS plugin that provides permission control for page resources.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors2

  •  
  •  

[8]ページ先頭

©2009-2025 Movatter.jp