加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

php – 如何正确使用Bearer令牌?

发布时间:2021-08-28 05:09:14 所属栏目:大数据 来源: https://www.jb51.cc
导读:我正在用PHP创建一个授权系统,我遇到了传递JWT令牌的Bearer方案,我读了RFC 6750.我有以下疑问: 这是如何改善安全性的? 成功授权和登录后,服务器在客户端使用JWT令牌响应客户端,现在当客户端发出另一个请求时,我不清楚如何实际执行此操作,我想在客户端的Aut

我正在用PHP创建一个授权系统,我遇到了传递JWT令牌的Bearer方案,我读了RFC 6750.我有以下疑问:

>这是如何改善安全性的?
>成功授权和登录后,服务器在客户端使用JWT令牌响应客户端,现在当客户端发出另一个请求时,我不清楚如何实际执行此操作,我想在客户端的Authorization头中发送令牌请求,所以现在我应该只将“Bearer”作为我在服务器上一个响应中收到的令牌前缀,如果是,则服务器在接收Authorization标头时,应该只用空格分割字符串,然后取第二个值从获得的数组然后解码吗?例如Authorization:Bearer fdbghfbfgbjhg_something,服务器应该如何处理这个,decodeFunc(explode(“”,$this-> getRequest() – > getHeader(“Authorization”))[1])?

解决方法:

1.提高安全性,因为如果在url中发送的标头中没有发送令牌,它将被网络系统记录,服务器日志….

2.获得Bearer令牌的良好功能

/** 
 * Get header Authorization
 * */
function getAuthorizationHeader(){
        $headers = null;
        if (isset($_SERVER['Authorization'])) {
            $headers = trim($_SERVER["Authorization"]);
        }
        else if (isset($_SERVER['HTTP_AUTHORIZATION'])) { //Nginx or fast CGI
            $headers = trim($_SERVER["HTTP_AUTHORIZATION"]);
        } elseif (function_exists('apache_request_headers')) {
            $requestHeaders = apache_request_headers();
            // Server-side fix for bug in old Android versions (a nice side-effect of this fix means we don't care about capitalization for Authorization)
            $requestHeaders = array_combine(array_map('ucwords', array_keys($requestHeaders)), array_values($requestHeaders));
            //print_r($requestHeaders);
            if (isset($requestHeaders['Authorization'])) {
                $headers = trim($requestHeaders['Authorization']);
            }
        }
        return $headers;
    }
/**
 * get access token from header
 * */
function getBearerToken() {
    $headers = getAuthorizationHeader();
    // HEADER: Get the access token from the header
    if (!empty($headers)) {
        if (preg_match('/Bearers(S+)/', $headers, $matches)) {
            return $matches[1];
        }
    }
    return null;
}

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读