node同一路由带token时解析不带则不解析并不报错

背景

使用node的express框架搭建后台系统,expressJWT做权限验证。
不管用户是否登录都走同一路由,如果携带了token则正常解析,不带token则不解析,并正常向下执行。

  • 以下是正常解析token, 并将其挂载到req的user上。
// 指定不需要解析和验证token的路由,可写多个自定义验证规则(在此仅匹配以unapi开头)
app.use(
	expressJWT({ 
		secret , // 秘钥
		algorithms:['HS256']
	})
	.unless({path:[/^\/unapi\//]}
))
  • 以下是自定义解析token
app.use(expressJWT({
    secret , // 秘钥
    algorithms:['HS256'],
    credentialsRequired: false, // 用来对无 Token 请求不进行解析和抛出异常。
    getToken: function fromHeaderOrQuerystring(req) {
   		// 如果携带token时正常解析
    	if (authorization && authorization.split(" ")[0] === "Bearer") {
    		return authorization.split(" ")[1];
        }
        return null;
        // 如果针对某一路由需要验证token时,可以手动抛出错误
        //if(!req.url.includes('/public/register')){
            //return new Error('{name:"UnauthorizedError"}')
        //}
    },
}))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值