如何正确使用不记名代币?

我正在制作一个授权系统,我遇到了这个传递JWT令牌的Bearer方案,我阅读了[RFC 6750][1]。我有以下疑问:PHP

  1. 这如何提高安全性?
  2. 在成功授权和登录后,服务器在其主体中用JWT令牌响应客户端,现在当客户端发出另一个请求时,我不清楚如何实际执行此操作,我想从请求中的授权标头中的客户端发送令牌,所以现在我应该只前缀“Bearer”到我在上一个响应中从服务器收到的令牌,如果是, 然后服务器在收到授权标头时,是否应该只拆分带有空格的字符串,并从获得的数组中获取第二个值,然后对其进行解码?例如,服务器应该如何处理这个问题?[1]: https://www.rfc-editor.org/rfc/rfc6750Authorization: Bearer fdbghfbfgbjhg_somethingdecodeFunc(explode(" ", $this->getRequest()->getHeader("Authorization"))[1])

答案 1

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

2.获取持有者代币的良好功能

/** 
 * 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('/Bearer\s(\S+)/', $headers, $matches)) {
            return $matches[1];
        }
    }
    return null;
}

答案 2

我建议使用以下正则表达式来检查它是否是有效的 jwt 令牌:

/Bearer\s((.*)\.(.*)\.(.*))/

并使用匹配项访问它[1]。

这是JWT令牌的结构,请参阅:https://jwt.io/


推荐