npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

v-permission-plugin

v1.1.0

Published

vue3后台管理系统路由权限插件

Downloads

4

Readme

permission 插件

介绍

vivien-permission 插件是一个基于后台管理系统中的路由菜单权限控制系统,通过 vue-router 全局控制后台管理系统的菜单权限。

功能

| 功能 | 介绍 | | ---------------- | -------------------------------------------------------- | | 菜单路由权限控制 | 通过接口返回权限路由名称,控制当前登录用户的路由权限 | | 按钮级别权限控制 | 通过接口返回按钮权限列表名称,控制当前登录用户的按钮权限 | | 单点登录 | 使用当前插件的系统和其他系统相互登录 |

安装

1. 安装相关依赖

该控制系统使用 vue-router 全局控制路由菜单权限,使用 js-cookie 作为 token 存储,依赖 pinia 存储用户菜单权限。

  • js-cookie
# npm
npm install js-cookie
# yarn
yarn install js-cookie
# pnpm
pnpm install js-cookie
  • pinia
# npm
npm install pinia
# npm
npm install pinia
# pnpm
pnpm install pinia
  • vue-router
# npm
npm install vue-router@4
# yarn
yarn install vue-router@4
# pnpm
pnpm install vue-router@4

2. 安装插件

# npm
npm install vivien-permission
# yarn
yarn install vivien-permission
# pnpm
pnpm install vivien-permission

使用插件

引入vivien-perimission

在你的项目中直接引入 XW-UI 的 vivien-perimission 插件

// 引入插件初始化方法
import initPermission from "vivien-perimission"

// 初始化插件
await initPermission(app, options, callback)

注意:该插件依赖 vue-router 和 pina,因此在初始化插件之前需要你预先初始化 vue-router 和 pinia,你也可以将 vue-router 是实例 router 对象传入插件中的 options.router 参数中,在插件中进行初始化路由和 pinia;

如果你没有预先创建 pinia 的实例,插件内部会预先创建。

下面是一个例子,展示了最简单的用法

import { createApp } from 'vue'
import App from './views/App.vue'
import { createPinia } from 'pinia'
import bootstrap from "vivien-perimission"
import { whiteList, asyncRoutes, basicRoutes } from "这是你的接口路由配置"
import { getAuthList, checkSSOLogin } from "这是你的接口"
import router from '这是你的router实例';  
import ElMessage from '这是你的消息提示';  

const app = createApp(App);
const pinia = createPinia()
// permission 内部将自动引入 router 和 pinia。因此你必须安装这两个插件
// 可以手动使用  router 和 pinia 插件,也可以不手动使用,去掉该语句即可
app.use(router).use(pinia)

const domain = '.example.com' // 你的系统域名
const publicPath = import.meta.env.VITE_PUBLIC_PATH // 系统 publicPath 目录
export async function setupMyPermission(app: App, router: any) {
    //定义一个符合 permissionOptions 接口的对象 
    const options = {
        router,
        publicPath: '/', // 系统 publicPath 目录
        whiteList, // 路由白名单
        asyncRoutes, // 异步路由
        basicRoutes, // 基础路由
        getAuthList, // 获取用户权限列表
        checkSSOLogin, // 检查oa登录状态
        storageType: 'cookiet',// 本地数据存储类型
        TOKEN_KEY: 'token-key', // token 存储 key 值
        SSO_TOKEN_KEYS: ['SIAMTGT', 'SIAMJWT'],

    }
    await initPermission(app, options, (params: any) => {
        console.log('权限初始化完成===', params)
    })
}
setupMyPermission(app)
app.mount('#app')

配置

bootstrap(app, options, callback)

| 参数 | 介绍 | | -------- | ------------------------------------------- | | app | vue3 实例,通过 createApp(App) 创建的实例 | | options | 对象类型,初始化参数值 | | callback | 初始化回调方法,回调参数中返回路由相关方法 |

options 参数

类型:

interface permissionOptionsType {
    routerMode?: 'hash' | 'history', // 路由模式
    publicPath?: string, // 路由根路径
    router?: Router,  // 路由对象(可选)
    whiteList?: string[], // 白名单
    asyncRoutes?: AppRouteModule[], // 异步路由
    basicRoutes?: AppRouteModule[], // 基础路由
    domain?: string | null, // oa 域名
    Message?: Function, // 消息提示
    getAuthList?: Function | null, // 获取用户权限列表接口
    checkSSOLogin?: Function | null, // 检查oa登录状态接口
    logout?: Function | null, //退出登录接口
    storageType?: 'localStorage' | 'sessionStorage' | 'cookie',  // 本地数据存储类型
    expires?: string,// 本地数据存储过期时间
    TOKEN_KEY?: string, // token key
    SSO_TOKEN_KEYS?: string | Array<any>// 单点登录 Keys
    Message?: Function | undefined, // 消息提示组件
    homeRoute: String | undefined // 首页路由(路径)
}

type AppRouteRecordRaw = RouteRecordRaw & {
  path: string; //路由路径
  name?: string; //路由名称
  order?: number | null | undefined; //路由排序
  component?: Component | string; //视图组件
  hidden?: boolean; //是否在菜单显示
  redirect?: string; //重定向路径
  children?: AppRouteRecordRaw[]; //子菜单
  meta?: RouteMeta //路由元信息
};

| 参数 | 介绍 | 类型 | | ------------ | ------------------------------------------------------- | --------------------------------------------------- | | router | vue-router 实例对象 | Router | | whiteList | 路由白名单 | Array<RouteName> 数组数组内每一项为路由名称 | | asyncRoutes | 异步加载的路由列表 | AppRouteModule[] 数组数组内每一项为路由对象 | | basicRoutes | 基础路由,非异步加载的路由 | AppRouteModule[] 数组数组内每一项为路由对象 | | getAuthList | 获取权限列表异步方法(接口) | Function | | checkSSOLogin | 方法,使用 oa token 换取当前系统的 token 接口, 登录系统 | Function | | domain | oa 域名 | String | | Message | 消息提示组件 | Function | | homeRoute | 默认首页路由(路径) | String |

getAuthList 接口

传入用户的 token,返回用户的菜单权限列表和按钮权限列表。

getAuthList({
    token: '' // 当前用户 token
})
  • 参数:

    • 类型: 对象
    • 参数值:
      • token: 当前登录系统的用户 token
  • 返回值:

    • 类型:对象

    • 返回值:

      • {
            menuNames: [], // 菜单权限名称列表
        	rule: [],// 按钮级别权限
        }
        • menuNames: 菜单权限列表,数组中每一项为路由名称。
        • rule: 按钮级别权限列表,数组中每一项为按钮权限标识字符串。

checkSSOLogin 接口

传入其他系统的 token,返回当前系统的 token,用于 其他系统 和 使用当前插件系统的 单点登录。

checkSSOLogin({
     ticketName: key,
     ticketValue: oaToken
})
  • 参数:

    • 类型: 对象。
    • 参数值:
      • ticketName: 其他系统的存储用户 token 的 key 值;
      • ticketValue: 其他系统的存储用户的 token ;
  • 返回值:

    • 类型:对象。

    • 返回值:

      • {
            token: '' //当前系统的 token 值
        }
        • token: 当前系统的 token 值。

callback 回调函数

初始化方法 bootstrap(app, options, callback) 第三个参数 callback 为回调函数,该回调函数的参数接收用于获取和控制权限相关的方法。

 bootstrap(app, options, ({
    getAsyncRoutes,
    getRoutes,
    getAddRoutes,
    getShowRouters,
    SetRoutes,
    SetRoute,
    ClearRoute,
    SetShowRouters,
    GenerateRoutes,
    getToken,
    getAuthority,
    SetToken,
    SetAuthority,
    GetAuthority,
    checkSSOLogin,
    Logout,
    ClearLocal,
    Globalstate: globalState,
    Getroutenames: getRouteNames,
    SetKeys: setKeys,
    SetStorage: setStorage
 })=> {
})

回调参数说明:

| 方法 | 说明 | 参数 | 返回值 | | -------------- | ---------------------------- | ------------------------------------------------------------ | ------------------------ | | getRoutes | 获取所有路由表 | | 所有路由表 | | getAddRoutes | 获取所有异步路由表 | | 所有异步路由表 | | getShowRouters | 获取二级菜单展示路由的路由表 | | 二级菜单展示路由的路由表 | | SetRoutes | 设置所有路由 | (asyncFilterRoutes: Array<T>, constantAsyncRoutes: Array<T>) asyncFilterRoutes 异步(权限)路由表constantAsyncRoutes 常规路由表 | | | SetRoute | 设置所有路由 | (routes: Array<RouteItem>)routes 所有路由表 | | | ClearRoute | 清空路由数据 | | | | SetShowRouters | 设置二级菜单路由 | (routes: RouteItem)routes:二级菜单显示的路由 | 二级菜单显示的路由 | | GenerateRoutes | 生成异步路由表 | (routesMenuNames: Array<RouteItem>, asyncRoutes: AppRouteModule[], basicRoutes: AppRouteModule[])routesMenuNames: 异步路由列表路由名称数组asyncRoutes:异步路由表basicRoutes:常规路由表 | 异步路由表 | | getToken | 获取用户 token | | 用户 token | | getAuthority | 获取用户权限列表 | | 用户权限列表 | | SetToken | 设置用户 token | {token: '用户token', oa: {ticketName:'其他系统token key', ticketValue:'其他系统 token 值' }} | | | SetAuthority | 设置用户权限列表 | {authority: []} | | | GetAuthority | 获取用户权限列表 | (getAuthList: Function, domain: string)getAuthList: 获取用户权限列表接口domain: 系统域名 | 用户权限列表 | | checkSSOLogin | 使用其他系统 token 登录系统 | (checkSSOLogin: Function, domain: string)checkSSOLogin: 用其他系统 token 换取当前系统的接口domain: 当前系统域名 | | | Logout | 退出当前系统 | (domain: string, logout?: Function)domain: 当前系统域名logout: 退出系统接口 | | | ClearLocal | 清空存储数据 | {domain: 当前系统域名} | |