request-headers - 如何从 webhook 请求者获取 HTTPS 标头
问题描述
我有一个 webhook 来接收我正在尝试配置的更新。我需要从标头中获取不记名令牌,但我无法检索它。有人可以阐明这个问题吗?我难住了!
接收网址是https://example.com/receive
$data = file_get_contents("php://input",true);
$events= json_decode($data, true);
解决方案
如果您正在寻找 OAuth 不记名令牌,这些令牌通常在请求 HTTP 授权标头中传输。在 PHP 中,这些可能有点难以阅读,因为不同的 Web 服务器有不同的方法来读取 Authorization 标头。
在这个答案中有一个很好的例子来说明如何读取不记名令牌。为方便起见,复制到这里:
<?PHP
/**
* Get hearder 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));
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;
}
?>
推荐阅读
- css - 在 VS 代码中更改颜色 CSS/SASS?
- reactjs - 使用 useReducer 时出现意外的渲染循环(并且没有 useEffect)
- angular - SPA 页面的安全性如何?
- sql - 根据另一列的最大值从表中选择列
- google-chrome - 如何将网络面板和来源面板并排放置在一起?
- excel - 通过在工作表 vba_excel 中搜索添加和删除组合框中的项目(建议)
- c# - 图像为 base64 的 RazorPage 不渲染图像
- python - else 在 for 循环之外,如果是,为什么 else 没有执行?
- sql - 如何在查询中包含多个字段及其每个余额的平均值
- java - 在 Spring Boot 属性中为嵌套类设置日志记录级别