vue iview 동적 라우팅 및 권한 확인 단계에 대한 자세한 설명
이번에는 vue iview 동적 라우팅 및 권한 확인 단계에 대해 자세히 설명하겠습니다. vue iview 동적 라우팅 및 권한 확인 사용 시 주의사항은 무엇인가요?
github에는 Vue에 동적 경로 추가에 대한 많은 예가 있습니다. 일부 프로젝트를 참조한 후 이 프로젝트는 iview 프레임워크를 기반으로 동적 경로 추가 및 메뉴 새로 고침을 완료했습니다. 도움이 필요한 다른 친구들을 돕기 위해 이제 구현 논리를 공유하고 함께 소통하고 배울 수 있습니다.
Github 주소
iview-dynamicRouter
목표 달성
클라이언트는 서버로부터 라우팅 및 권한 데이터를 받은 후 프로젝트의 라우팅 및 메뉴 목록을 새로 고치고 권한 제어를 수행합니다.
프로젝트 기반
기본 프레임워크: iview 컴포넌트 라이브러리 공식 템플릿 프로젝트 iview-admin의 템플릿 브랜치 프로젝트, 이 프로젝트는 iview-admin의 기본 프레임워크 코드입니다. 프로젝트 주소: iview-admin
구현 로직
동적 라우팅 제어 로딩
일반적으로 동적 라우팅 제어는 두 가지 유형으로 나누어집니다. 하나는 모든 라우팅 데이터를 로컬 파일에 저장하고, 그 다음 획득하는 것입니다. 서버에서 사용자의 권한 정보를 가져오고, 경로 점프 시 권한 판단 후크를 추가합니다. 사용자가 이동하는 페이지가 권한 목록에 없으면 점프가 금지됩니다. 다른 하나는 오류 처리 페이지, 권한 없음 제어 페이지 등 기본 경로만 로컬에 저장하고 서버는 사용자 권한에 따라 해당 라우팅 데이터를 발급하고 클라이언트는 허용 경로를 가져오는 것입니다. 이러한 데이터를 사용하여 작업을 수행합니다. 동적 생성 및 경로 추가를 위해 이 문서에서는 두 번째 방법을 채택합니다.
iview-admin 프로젝트는 경로를 세 가지 유형으로 나눕니다.
로그인, 404, 403 및 기타 오류 페이지 경로와 같은 기본 구성 요소의 하위 페이지로 표시되지 않는 페이지 경로
하위로; - 홈 페이지 라우팅
과 같이 표시되지만 왼쪽 메뉴에 표시되지 않는 기본 구성 요소 Router otherRouter의 페이지는 기본 구성 요소의 하위 페이지로 표시되며 왼쪽 메뉴 appRouter에 표시됩니다.
프레임워크 및 router.addRoutes(routes)
完成路由列表的动态添加;第二部分是因为 iview-admin
breadcrumb 탐색에서 appRouter를 통과하여 라우팅 정보를 얻으므로 전역 액세스를 위해 라우팅 데이터도 vuex에 저장해야 합니다.
라우팅 주소를 찾을 수 없는 경우 기본적으로 404 오류 페이지로 이동하면 환경이 매우 열악하므로 404 경로가 먼저 라우팅 규칙에 기록되지 않고 동적 라우팅과 함께 로드됩니다.
메인 코드는 다음과 같이 구현됩니다. 데이터 요청 및 라우팅 노드 생성//util.js //生成路由 util.initRouter = function (vm) { const constRoutes = []; const otherRoutes = []; // 404路由需要和动态路由一起注入 const otherRouter = [{ path: '/*', name: 'error-404', meta: { title: '404-页面不存在' }, component: 'error-page/404' }]; // 模拟异步请求 util.ajax('menu.json').then(res => { var menuData = res.data; util.initRouterNode(constRoutes, menuData); util.initRouterNode(otherRoutes, otherRouter); // 添加主界面路由 vm.$store.commit('updateAppRouter', constRoutes.filter(item => item.children.length > 0)); // 添加全局路由 vm.$store.commit('updateDefaultRouter', otherRoutes); // 刷新界面菜单 vm.$store.commit('updateMenulist', constRoutes.filter(item => item.children.length > 0)); }); }; //生成路由节点 util.initRouterNode = function (routers, data) { for (var item of data) { let menu = Object.assign({}, item); menu.component = lazyLoading(menu.component); if (item.children && item.children.length > 0) { menu.children = []; util.initRouterNode(menu.children, item.children); } //添加权限判断 meta.permission = menu.permission ? menu.permission : null; //添加标题 meta.title = menu.title ? menu.title : null; menu.meta = meta; } };
동적 로딩 구성 요소
//lazyLoading.js export default (url) =>()=>import(`@/views/${url}.vue`) Store缓存实现 //app.js // 动态添加主界面路由,需要缓存 updateAppRouter (state, routes) { state.routers.push(...routes); router.addRoutes(routes); }, // 动态添加全局路由,不需要缓存 updateDefaultRouter (state, routes) { router.addRoutes(routes); }, // 接受前台数组,刷新菜单 updateMenulist (state, routes) { state.menuList = routes; }
//main.js mounted () { // 调用方法,动态生成路由 util.initRouter(this); }
권한 제어
동적 라우팅 구현과 유사 조작 권한 제어는 일반적으로 두 가지 유형으로 나누어집니다. 첫 번째는 페이지가 표시될 때 권한이 제어되지 않는 것입니다. 그런 다음 조작이 시작되면 권한 판단이 수행됩니다. 사용자에게 작업에 대한 권한이 있으면 통과합니다. 그렇지 않으면 사용자에게 권한이 없다는 알림이 표시됩니다. 두 번째 방법은 페이지가 로드될 때 권한을 판단하는 것이며, 권한 없는 작업은 표시되지 않습니다. 나는 개인적으로 사용자가 보는 것이 작동 가능해야 한다고 생각하는 두 번째 방법을 선호합니다. 그렇지 않으면 버튼을 클릭한 다음 권한이 없다는 메시지가 표시되는 것이 매우 불편할 것입니다. 이 프로젝트의 아이디어 소스는 참조 블로그 게시물을 참조하세요. 원래 블로거의 구체적인 아이디어는 라우팅 구조의 메타 필드에 주요 코드 구현은 다음과 같습니다. 라우팅 데이터에 권한 필드를 추가하여 권한 목록을 저장합니다//menu.json,模拟异步请求数据 [ { "path": "/groupOne", "icon": "ios-folder", "name": "system_index", "title": "groupOne", "component": "Main", "children": [ { "path": "pageOne", "icon": "ios-paper-outline", "name": "pageOne", "title": "pageOne", "component": "group/page1/page1", "permission":["del"] }, ... ] } ]
在遍历生成路由节点时,将 permission 字段数据存入路由节点 meta 属性中
//util.js //生成路由节点 util.initRouterNode = function (routers, data) { for (var item of data) { .... //添加权限判断 meta.permission = menu.permission ? menu.permission : null; ... } };
定义全局命令组件,读取路由 permission 属性值获得权限列表,如果该不权限在权限列表中,则删除节点
//hasPermission.js const hasPermission = { install (Vue, options) { Vue.directive('hasPermission', { bind (el, binding, vnode) { let permissionList = vnode.context.$route.meta.permission; if (permissionList && permissionList.length && !permissionList.includes(binding.value)) { el.parentNode.removeChild(el); } } }); } }; export default hasPermission;
权限组件使用示例:
<template> <p> <h1>page1</h1> <Button v-hasPermission="'add'">添加</Button> <Button v-hasPermission="'edit'">修改</Button> <Button v-hasPermission="'del'">删除</Button> </p> </template>
全局注册组件
// main.js import hasPermission from '@/libs/hasPermission.js'; Vue.use(hasPermission);
这种权限控制方法的优点就是,不管是管理配置还是页面处理逻辑都相对简单,没有很多重复的代码判断和节点处理,在参考对比了网上几种实现方式后,个人比较推荐这一种方法。
页面标签和面包屑导航
在我看来,页面标签和面包屑都属于系统中锦上添花的页面相关控件,提高页面管理的便捷性,在iview官方admin项目中已经实现了这两个组件。所以这个项目中,只是将其进行移植,实现了组件功能,没有深入了解,感兴趣的可以仔细研究。
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
위 내용은 vue iview 동적 라우팅 및 권한 확인 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











우리는 일반적으로 정부나 기타 기관으로부터 PDF 파일을 받으며, 일부는 디지털 서명이 포함되어 있습니다. 서명을 확인한 후 SignatureValid 메시지와 녹색 확인 표시가 표시됩니다. 서명이 확인되지 않으면 유효성을 알 수 없습니다. 서명을 확인하는 것이 중요합니다. PDF에서 이를 수행하는 방법을 살펴보겠습니다. PDF에서 서명을 확인하는 방법 PDF 형식의 서명을 확인하면 더욱 신뢰할 수 있고 문서가 승인될 가능성이 높아집니다. 다음과 같은 방법으로 PDF 문서의 서명을 확인할 수 있습니다. Adobe Reader에서 PDF를 엽니다. 서명을 마우스 오른쪽 버튼으로 클릭하고 서명 속성 표시를 선택합니다. 서명자 인증서 표시 버튼을 클릭합니다. 신뢰 탭에서 신뢰할 수 있는 인증서 목록에 서명을 추가합니다. 서명 확인을 클릭하여 확인을 완료합니다.

1. WeChat을 연 후 검색 아이콘을 클릭하고 WeChat 팀을 입력한 후 아래 서비스를 클릭하여 들어갑니다. 2. 입력 후 좌측 하단의 셀프 서비스 도구 옵션을 클릭하세요. 3. 클릭 후, 위 옵션 중 보조검증 차단해제/이의제기 옵션을 클릭해 주세요.

인도 금융 시스템 코드는 약어입니다. 전자 자금 이체 시스템에 참여하는 인도 은행 지점은 특수 11자리 코드로 식별됩니다. 인도중앙은행은 인터넷 거래에서 이 코드를 사용하여 은행 간 자금을 이체합니다. IFSC 코드는 두 부분으로 나뉩니다. 은행은 처음 4자로 식별되고, 지점은 마지막 6자로 식별됩니다. NEFT(National Electronic Funds Transfer), RTGS(Real Time Gross Settlement) 및 IMPS(Immediate Payment Service)는 IFSC 코드가 필요한 전자 거래 중 일부입니다. 방법 정규식을 사용하여 IFSC 코드를 검증하는 몇 가지 일반적인 방법은 다음과 같습니다. 길이가 올바른지 확인합니다. 처음 4자를 확인하세요. 다섯 번째 문자를 확인하세요.Che

golang에서는 입력이 전자인지 확인하기 위해 유니코드 인코딩과 룬 유형이 필요합니다. 유니코드 인코딩은 전자 및 반자 문자를 포함하는 문자 집합의 각 문자에 고유한 숫자 코드 포인트를 할당하는 문자 인코딩 표준입니다. 룬 유형은 golang에서 유니코드 문자를 나타내는 데 사용되는 유형입니다. 첫 번째 단계는 입력을 룬 유형 슬라이스로 변환하는 것입니다. 이는 golang의 []rune 유형을 사용하여 변환할 수 있습니다.

Golang은 일상적인 개발에서 종종 문자열 처리를 포함하는 고성능의 현대적인 프로그래밍 언어입니다. 그중에서도 입력이 대문자인지 확인하는 것이 일반적인 요구 사항입니다. 이번 글에서는 Golang에서 입력이 대문자인지 확인하는 방법을 소개하겠습니다. 방법 1: 유니코드 패키지를 사용합니다. Golang의 유니코드 패키지는 문자의 인코딩 유형을 결정하는 일련의 함수를 제공합니다. 대문자의 경우 해당 인코딩 범위는 65-90(십진수)이므로 유니코드를 사용할 수 있습니다.

PHP8은 최신 버전의 PHP로 프로그래머에게 더 많은 편의성과 기능을 제공합니다. 이 버전은 보안과 성능에 특별히 중점을 두고 있으며 주목할만한 새로운 기능 중 하나는 확인 및 서명 기능이 추가된 것입니다. 이 문서에서는 이러한 새로운 기능과 그 용도에 대해 자세히 살펴보겠습니다. 확인 및 서명은 컴퓨터 과학에서 매우 중요한 보안 개념입니다. 이는 전송된 데이터가 완전하고 확실한지 확인하는 데 자주 사용됩니다. 온라인 거래 및 민감한 정보를 처리할 때 확인 및 서명이 더욱 중요해집니다. 누군가가 데이터를 조작할 수 있다면 잠재적으로 그럴 수 있기 때문입니다.

현대 온라인 세계에서 웹사이트 보안과 사용자 개인 정보 보호는 점점 더 중요한 주제가 되었습니다. 그 중 인간-기계 검증이라는 기술적 방법은 악의적인 공격을 방지하는 데 없어서는 안 될 방법 중 하나가 되었습니다. GooglereCAPTCHA는 인간-컴퓨터 검증에 널리 사용되는 도구입니다. 그 개념은 사람들의 마음속에 깊이 뿌리박혀 있으며, 그 존재는 우리가 매일 사용하는 많은 웹사이트에서도 볼 수 있습니다. 이 기사에서는 PHP에서 확인을 위해 GooglereCAPTCHA를 사용하는 방법을 살펴보겠습니다.

점점 더 많은 사용자들이 win11 시스템을 업그레이드하기 시작하고 있습니다. 사용자마다 사용 습관이 다르기 때문에 여전히 많은 사용자들이 ie11 브라우저를 사용하고 있습니다. 그렇다면 win11 시스템에서 ie 브라우저를 사용할 수 없으면 어떻게 해야 합니까? windows11은 여전히 ie11을 지원하나요? 해결책을 살펴보겠습니다. win11에서 ie11 브라우저를 사용할 수 없는 문제 해결 방법 1. 먼저 시작 메뉴를 마우스 오른쪽 버튼으로 클릭한 후 "명령 프롬프트(관리자)"를 선택하여 엽니다. 2. 연 후 "Netshwinsockreset"을 직접 입력하고 Enter를 눌러 확인합니다. 3. 확인 후 "netshadvfirewallreset&rdqu"를 입력하세요.
