vue-element-admin 登录拦截设置白名单

用途:

在vue中我们一般把登录拦截及权限处理在permision.js文件中并在min.js中导入;

当页面跳转时判断用户是否登录及token是否过期,若token过期/未登录则会重定向到login页面;

但有些项目除了登录页还有用户注册页面,此时需要设置白名单使得可以直接从login页面跳转至regist页面而不会被重定向到login页;

permision.js:

import router from './router'
import store from './store'
import {
  Message
} from 'element-ui'
const whiteList = ['/login','/regist'] //白名单

router.beforeEach(async (to, from, next) => {
  // 确定用户是否已经登录
  const hasToken = localStorage.getItem('token')

  if (hasToken) {
    if (to.path === '/login') {
      // 如果已登录,则重定向到主页
      next({
        path: '/'
      })
    }else{
      //权限处理部分,可参考vue-element-admin框架中permision.js权限处理部分
    }
  } else {
    //没有token的情况
    if (whiteList.indexOf(to.path) !== -1) {
      // 如果在白名单内则直接跳转
      next()
    } else {
      // 其余页面重定向到登录页
      next(`/login?redirect=${to.path}`)
    }
  }
})

切记要在min.js中引入该js:  import './permission'

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
vue-element-admin中,可以使用axios进行转发设置。axios是一个基于Promise的HTTP客户端,用于浏览器和Node.js。它可以将请求发送到后端服务器并接收响应数据。 要设置axios的转发,你可以按照以下步骤进行操作: 1. 打开项目目录下的`src/utils/request.js`文件。这是封装了axios的请求方法的文件。 2. 在该文件中找到`createRequest`函数,在函数体内找到`service`对象。 3. `service`对象是一个axios实例,你可以通过该实例来设置转发。例如,可以使用`service.interceptors.request.use()`方法来添加请求拦截器,使用`service.interceptors.response.use()`方法来添加响应拦截器。 4. 在请求拦截器中,你可以对请求进行一些处理,例如添加请求头、设置token等。 5. 在响应拦截器中,你可以对响应进行一些处理,例如对错误进行统一处理、对返回数据进行格式化等。 6. 另外,你还可以在`src/api`文件夹中的每个API接口文件中,根据需要使用axios进行转发设置。 总结起来,要在vue-element-admin项目中设置axios的转发,你需要找到`src/utils/request.js`文件,并根据需要使用`service.interceptors.request.use()`和`service.interceptors.response.use()`方法进行拦截器的设置。这样可以对请求和响应进行统一处理和转发。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue-element-admin:vue-element-admin](https://download.csdn.net/download/weixin_42168745/16228234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue-element-admin-template](https://download.csdn.net/download/weixin_42142062/15991791)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [浏览器显示数据库中数据的条形图柱状图 前后端分离vue.js+spring boot 计算机软件工程课程设计毕业设计 ...](https://download.csdn.net/download/Amzmks/88275824)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阁下何不同风起?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值