Apache 2.4 的 mod_proxy_fcgi,通常用于代理对 PHP-FPM 的请求,可能会遇到将授权标头传递给外部 FastCGI 进程。这可以阻止用户访问某些功能,例如 APC 的用户缓存监视器。
原因
出于安全原因,各种 Apache 模块可能会剥离授权标头。识别负责的特定模块可能具有挑战性。
使用 SetEnvIf 的解决方法
要避免此问题,您可以通过 env:
将标头直接传递给 PHPSetEnvIf Authorization "(.*)" HTTP_AUTHORIZATION=
其他注意事项
在某些情况下,通过 env 传递标头可能还不够。您可能还需要修改 PHP 代码以从 $_SERVER['REDIRECT_HTTP_AUTHORIZATION'] 而不是 $_SERVER['HTTP_AUTHORIZATION'] 访问授权标头。
替代解决方案
如果 SetEnvIf 解决方法无效,另一种可能的解决方案是检查 Apache 配置中与标头传递相关的设置。
结论
从 Apache 2.4 传递授权标头PHP-FPM 可能会出现问题,但通过了解潜在原因并实施适当的解决方法,您可以确保用户能够访问必要的特性和功能。
以上是如何将授权标头从 Apache 2.4 传递到 PHP-FPM?的详细内容。更多信息请关注PHP中文网其他相关文章!