Jwtauth 自定义认证头信息

自定义认证头

项目使用的tymon/jwt-auth包作为 token 的认证,过程中需要迁移项目,因为之前公司的 token 头部使用自定义的,并且他们还修改了包的头信息。就是下面头部信息。

class AuthHeaders implements ParserContract
{
    // 下面这两处就是被修改的
    protected $header = 'authorization'; 

    protected $prefix = 'bearer';
}

迁移项目过程了,因为拉取了新的包,所以还要去动包的信息,这是极其不合理的行为。所以就在包中尝试找到了更好的解决办法。如果在项目迁移过程中遇到了类似的问题该如何去做呢?这里只提供了我能想到的解决办法。需要在 AppServiceProvider 中加入该方法就可以了。

    protected function setAuthHeader()
    {
        $chain = $this->app['tymon.jwt.parser']->getChain();

        $chain[0] = $chain[0]->setHeaderPrefix('项目的 token 前缀')->setHeaderName('项目的头信息 key');

        $this->app['tymon.jwt.parser']->setChain($chain);
    }

如果你有更好的办法可以提供,欢迎留言或者改进。

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 2

我这这样解决的,新增一个中间件,中间件中重新给标头赋值
.
file

4年前 评论
JaguarJack (楼主) 4年前

大佬,你这个方法加到AppServiceProvider没用啊,还是验证失败
还有这个方法在哪里调用啊,我是在boot里面调用的

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!