土鳖屋源码社区

 找回密码
 欢迎注册

QQ登录

只需一步,快速开始

03广告位出售中
广告出售中
广告位
联盟招募 收益最高
免费建网站 服务器特价
网维体微信营销平台
【多线高防】无视一切攻击!织梦模板
站长平台 精确提升SEO
21广告位高权重链接招租
微信抢红包源码云主机
国内/香港主机/试用免费
微信小程序微信营销项目
小程序
源码商城棋牌源码
查看: 19|回复: 0

[其他] php 判断是否是反向代理https

[复制链接]
弗罗多 发表于 2018-12-5 14:46 | 显示全部楼层 |阅读模式

需要使用php判断当前访问的http还是https,根据访问类型返回相应数据。google发现$_SERVER可以解决。

这里是相关参数:

  1. $_SERVER['PHP_SELF'] #当前正在执行脚本的文件名,与 document root相关。
  2. $_SERVER['argv'] #传递给该脚本的参数。
  3. $_SERVER['argc'] #包含传递给程序的命令行参数的个数(如果运行在命令行模式)。
  4. $_SERVER['GATEWAY_INTERFACE'] #服务器使用的 CGI 规范的版本。例如,“CGI/1.1”。
  5. $_SERVER['SERVER_NAME'] #当前运行脚本所在服务器主机的名称。
  6. $_SERVER['SERVER_SOFTWARE'] #服务器标识的字串,在响应请求时的头部中给出。
  7. $_SERVER['SERVER_PROTOCOL'] #请求页面时通信协议的名称和版本。例如,“HTTP/1.0”。
  8. $_SERVER['REQUEST_METHOD'] #访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。
  9. $_SERVER['QUERY_STRING'] #查询(query)的字符串。
  10. $_SERVER['DOCUMENT_ROOT'] #当前运行脚本所在的文档根目录。在服务器配置文件中定义。
  11. $_SERVER['HTTP_ACCEPT'] #当前请求的 Accept: 头部的内容。
  12. $_SERVER['HTTP_ACCEPT_CHARSET'] #当前请求的 Accept-Charset: 头部的内容。例如:“iso-8859-1,*,utf-8”。
  13. $_SERVER['HTTP_ACCEPT_ENCODING'] #当前请求的 Accept-Encoding: 头部的内容。例如:“gzip”。
  14. $_SERVER['HTTP_ACCEPT_LANGUAGE']#当前请求的 Accept-Language: 头部的内容。例如:“en”。
  15. $_SERVER['HTTP_CONNECTION'] #当前请求的 Connection: 头部的内容。例如:“Keep-Alive”。
  16. $_SERVER['HTTP_HOST'] #当前请求的 Host: 头部的内容。
  17. $_SERVER['HTTP_REFERER'] #链接到当前页面的前一页面的 URL 地址。
  18. $_SERVER['HTTP_USER_AGENT'] #当前请求的 User_Agent: 头部的内容。
  19. $_SERVER['HTTPS'] — 如果通过https访问,则被设为一个非空的值(on),否则返回off
  20. $_SERVER['REMOTE_ADDR'] #正在浏览当前页面用户的 IP 地址。
  21. $_SERVER['REMOTE_HOST'] #正在浏览当前页面用户的主机名。
  22. $_SERVER['REMOTE_PORT'] #用户连接到服务器时所使用的端口。
  23. $_SERVER['SCRIPT_FILENAME'] #当前执行脚本的绝对路径名。
  24. $_SERVER['SERVER_ADMIN'] #管理员信息
  25. $_SERVER['SERVER_PORT'] #服务器所使用的端口
  26. $_SERVER['SERVER_SIGNATURE'] #包含服务器版本和虚拟主机名的字符串。
  27. $_SERVER['PATH_TRANSLATED'] #当前脚本所在文件系统(不是文档根目录)的基本路径。
  28. $_SERVER['SCRIPT_NAME'] #包含当前脚本的路径。这在页面需要指向自己时非常有用。
  29. $_SERVER['REQUEST_URI'] #访问此页面所需的 URI。例如,“/index.html”。
  30. $_SERVER['PHP_AUTH_USER'] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户名。
  31. $_SERVER['PHP_AUTH_PW'] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码。
  32. $_SERVER['AUTH_TYPE'] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是认证的类型。
  33. ---------------------
复制代码
  1. $http_type = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
  2. ---------------------

复制代码
但是我$_SERVER打出来的并没有$_SERVER['HTTPS']啊!看到我的$_SERVER我恍然大悟我用nginx做了一层反向代理。证书挂在nginx上,apache还是走的http,所以返回的还是http啊

没办法,只能自己想办法解决了。

通知前端访问网页的时候get方式传值,比如是https://test.com/test.php?isHttps=1
  1. if(isset($_GET['isHttps']) && $_GET['isHttps'] == '1'){
  2.   echo 'https://test.com/';
  3. }else{
  4.   echo 'http://test.com/';
  5. }
复制代码

我在test.php中这样写
---------------------
判断是传isHttps了,值是不是1,是1 返回https的链接,搞定。

    您需要登录后才可以回帖 登录 | 欢迎注册

    本版积分规则

    QQ|小黑屋|手机版|土鳖屋源码社区 ( 豫ICP备14000521号-2 )

    GMT+8, 2018-12-19 15:21

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    豫公网安备 41088202000172号

    快速回复 返回顶部 返回列表