php 判断是否是https

2 篇文章 0 订阅

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

这里是相关参数:

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

这样用

$http_type = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://'; 

但是,

但是我$_SERVER打出来的并没有$_SERVER['HTTPS']啊!

array(31) { ["HTTP_HOST"]=> string(22) "www.test.com:8080" ["HTTP_CONNECTION"]=> string(5) "close" ["HTTP_UPGRADE_INSECURE_REQUESTS"]=> string(1) "1" ["HTTP_USER_AGENT"]=> string(120) "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.98 Safari/537.36" ["HTTP_ACCEPT"]=> string(74) "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8" ["HTTP_ACCEPT_ENCODING"]=> string(23) "gzip, deflate, sdch, br" ["HTTP_ACCEPT_LANGUAGE"]=> string(14) "zh-CN,zh;q=0.8" ["PATH"]=> string(133) "/usr/local/apache/bin:/usr/local/php/bin:/usr/local/nginx/sbin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin" ["LD_LIBRARY_PATH"]=> string(21) "/usr/local/apache/lib" ["SERVER_SIGNATURE"]=> string(0) "" ["SERVER_SOFTWARE"]=> string(30) "Apache/2.4.2 (Unix) PHP/5.4.16" ["SERVER_NAME"]=> string(17) "www.test.com" ["SERVER_ADDR"]=> string(9) "127.0.0.1" ["SERVER_PORT"]=> string(4) "8080" ["REMOTE_ADDR"]=> string(9) "127.0.0.1" ["DOCUMENT_ROOT"]=> string(18) "/workspace/test" ["REQUEST_SCHEME"]=> string(4) "http" ["CONTEXT_PREFIX"]=> string(0) "" ["CONTEXT_DOCUMENT_ROOT"]=> string(18) "/workspace/test" ["SERVER_ADMIN"]=> string(15) "you@example.com" ["SCRIPT_FILENAME"]=> string(27) "/workspace/test/test.php" ["REMOTE_PORT"]=> string(5) "53414" ["GATEWAY_INTERFACE"]=> string(7) "CGI/1.1" ["SERVER_PROTOCOL"]=> string(8) "HTTP/1.0" ["REQUEST_METHOD"]=> string(3) "GET" ["QUERY_STRING"]=> string(0) "" ["REQUEST_URI"]=> string(9) "/test.php" ["SCRIPT_NAME"]=> string(9) "/test.php" ["PHP_SELF"]=> string(9) "/test.php" ["REQUEST_TIME_FLOAT"]=> float(1481789441.205) ["REQUEST_TIME"]=> int(1481789441) }

看到我的$_SERVER我恍然大悟我用nginx做了一层反向代理。证书挂在nginx上,apache还是走的http,所以返回的还是http啊

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

通知前端访问网页的时候get方式传值,比如是https://test.com/test.php?isHttps=1

我在test.php中这样写

if(isset($_GET['isHttps']) && $_GET['isHttps'] == '1'){
  echo 'https://test.com/';
}else{
  echo 'http://test.com/';
}

判断是传isHttps了,值是不是1,是1 返回https的链接,搞定。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 可以使用 PHP 内置的 checkdate 函数来判断是否是时间戳。该函数接受三个参数,分别是月份、日期和年份,如果传入的参数是一个合法的日期,则返回 true,否则返回 false。使用时间戳可以转换成时间,然后利用这个函数判断是否是时间戳. 示例: ``` $timestamp = time(); $date = getdate($timestamp); if (checkdate($date['mon'], $date['mday'], $date['year'])) { echo "It's a valid timestamp!"; } else { echo "It's not a valid timestamp!"; } ``` ### 回答2: 要判断一个字符串是否是合法的时间戳,可以使用PHP内置的函数进行判断。以下是一种判断方法: 首先判断字符串是否满足时间戳的格式,即只包含数字且长度为10或13。可以使用正则表达式进行判断,比如使用preg_match函数: ```php function isTimestamp($str) { return preg_match('/^\d{10}$|^\d{13}$/', $str); } ``` 上述代码中的正则表达式表示字符串要么是10位数字,要么是13位数字,符合这两种情况之一即被认为是时间戳。 接下来可以使用is_numeric函数判断字符串是否为数字,并使用strlen函数获取字符串的长度,根据长度判断是否为时间戳: ```php function isTimestamp($str) { if (is_numeric($str)) { $length = strlen($str); if ($length == 10 || $length == 13) { return true; } } return false; } ``` 这样就可以通过调用isTimestamp函数来判断一个字符串是否是时间戳了。例如: ```php if (isTimestamp('1591591591')) { echo '是时间戳'; } else { echo '不是时间戳'; } ``` 上述代码中的字符串'1591591591'是一个10位数的时间戳,因此会输出'是时间戳'。 ### 回答3: 在PHP中,我们可以使用`is_numeric`函数来判断一个字符串是否为时间戳。具体的步骤如下: 1. 首先,我们需要获取到待判断的字符串,可以通过从用户输入、数据库中获取或者其他方式获得。 2. 然后,我们可以使用`is_numeric`函数判断该字符串是否为一个数值类型。如果是数值类型,说明该字符串可能是一个时间戳。 3. 进一步确认该字符串是否为时间戳,可以使用`strtotime`函数将该字符串转换为UNIX时间戳。如果转换成功,说明该字符串确实是一个时间戳。 4. 最后,我们可以根据判断结果的布尔值来执行相应的逻辑。 下面是一个示例代码: ```php // 待判断的字符串 $timestamp_str = "1588888888"; // 判断字符串是否为数值类型 if (is_numeric($timestamp_str)) { // 将字符串转换为UNIX时间戳 $timestamp = strtotime($timestamp_str); // 判断转换结果是否为null if ($timestamp !== false) { // 字符串是一个有效的时间戳 echo "是一个时间戳。"; } else { // 字符串不是一个时间戳 echo "不是一个时间戳。"; } } else { // 字符串不是一个数值类型 echo "不是一个时间戳。"; } ``` 使用以上步骤和示例代码,我们可以判断一个字符串是否为时间戳。在判断过程中,我们首先判断字符串是否为数值类型,然后再使用`strtotime`函数将其转换为UNIX时间戳,从而确认其是否为时间戳。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值