
本文介绍如何通过 JavaScript 脚本从客户端获取 TLS 版本信息,并通过 GET 或 POST 请求将其发送到服务器,以便 PHP 应用在 Nginx 环境下获取客户端的 TLS 版本。这种方法利用了第三方 API howsmyssl.com,无需修改 Nginx 或 PHP-FPM 的配置。
获取客户端 TLS 版本信息
由于 Nginx 本身默认不直接将客户端 TLS 版本信息传递给 PHP-FPM,我们需要借助其他方法来实现。一个可行的方案是使用 JavaScript 在客户端获取 TLS 信息,然后通过 HTTP 请求将其发送到服务器。
howsmyssl.com 提供了一个免费的 API,允许开发者获取客户端的 TLS 版本。我们可以使用以下 JavaScript 代码来获取并处理这些信息:
立即学习“PHP免费学习笔记(深入)”;
代码解释:
dmSOBC SHOP网店系统由北京时代胜腾信息技术有限公司(http://www.webzhan.com)历时6个月开发完成,本着简单实用的理念,商城在功能上摒弃了外在装饰的一些辅助功能,尽可能的精简各项模块开发,做到有用的才开发,网店V1.0.0版本开发完成后得到了很多用户的使用并获得了好评,公司立即对网店进行升级,其中包括修正客户提出的一些意见和建议,现对广大用户提供免费试用版本,如您在使用
- parseTLSinfo(TLSinf) 函数: 这是一个回调函数,当 howsmyssl.com 的脚本加载完成后会被调用。TLSinf 参数包含客户端的 TLS 信息。
- sendTLSInfoToServer(tlsInfo) 函数: 这个函数负责将 TLS 信息发送到服务器。 示例代码使用 GET 请求将 tlsInfo.tls_version 作为参数发送到 /your-php-script.php。 你也可以选择使用 POST 请求,这取决于你的应用需求。
- : 这行代码引入 howsmyssl.com 的脚本,并指定 parseTLSinfo 作为回调函数。
在 PHP 中获取 TLS 信息
在 PHP 脚本 (your-php-script.php) 中,你可以通过 $_GET 或 $_POST 数组来获取客户端发送的 TLS 信息:
注意事项:
- 安全性: 由于 TLS 信息是通过客户端发送的,存在被篡改的风险。 请务必对接收到的数据进行验证和清理,以防止安全漏洞。 考虑使用 HTTPS 连接来保护数据传输。
- CORS: 如果你的 PHP 脚本和包含 JavaScript 代码的页面位于不同的域名下,你需要配置 CORS (跨域资源共享) 允许跨域请求。
- 错误处理: 在实际应用中,添加适当的错误处理机制,例如检查 fetch 请求是否成功,以及处理 howsmyssl.com API 可能出现的错误。
- 隐私: 确保你符合相关的隐私法规,并在用户知情的情况下收集和处理 TLS 信息。
总结
通过结合 JavaScript 和第三方 API,我们可以绕过 Nginx 默认行为,获取客户端的 TLS 版本信息,并将其传递给 PHP 应用。虽然这种方法需要客户端配合,但它提供了一种无需修改 Nginx 配置即可实现此功能的解决方案。请务必注意安全性和隐私问题,并根据你的具体需求进行适当的调整。










