Сценарий: Я работаю на веб-сервере Apache с некоторым PHP. Я указываю свой браузер на https://my.example.com/test.php, в котором есть следующие строки кода:
<pre>
<?php
print_r($_SERVER);
?>
</pre>
Значение, напечатанное для SERVER_PORT, 80, а не 443. Но если я перейду к https://my.example.com:80/test.php веб-серверу (Apache) barfs (Произошла ошибка во время подключения к my.example.com:80. SSL получил запись, которая превысила максимально допустимую длину. Код ошибки: ssl_error_rx_record_too_long). Если я перейду к https://my.example.com:443/test.php, тогда URL-адрес перенаправляется на https://my.example.com/test.php без ошибок или проблем, кроме того, что мой PHP выдает, что порт сервера равен 80 вместо 443.
Вот соответствующий раздел из файла conf.d/ssl.conf (я удалил то, что, по моему мнению, посторонними директивами и заменил фактический IP-адрес словом IP_ADDRESS):
Listen IP_ADDRESS:443
<VirtualHost *:443>
ServerName my.example.com
ServerAlias my
DocumentRoot "/path/to/document_root/htdocs"
Options +Indexes
</VirtualHost>
Вот полная распечатка переменной $_SERVER (с данными моего сервера, отредактированными/измененными на анонимные примеры):
Array
(
[HTTP_HOST] => my.example.com
[HTTP_USER_AGENT] => Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2.11) Gecko/20101012 Firefox/3.6.11
[HTTP_ACCEPT] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
[HTTP_ACCEPT_LANGUAGE] => en-us,en;q=0.5
[HTTP_ACCEPT_ENCODING] => gzip,deflate
[HTTP_ACCEPT_CHARSET] => ISO-8859-1,utf-8;q=0.7,*;q=0.7
[HTTP_KEEP_ALIVE] => 115
[HTTP_CONNECTION] => keep-alive
[HTTP_COOKIE] => PHPSESSID=randomstring_yes_I'm_that_paranoid
[PATH] => /sbin:/usr/sbin:/bin:/usr/bin
[SERVER_SIGNATURE] =>
Apache/2.2.3 (Red Hat) Server at my.example.com Port 80
[SERVER_SOFTWARE] => Apache/2.2.3 (Red Hat)
[SERVER_NAME] => my.example.com
[SERVER_ADDR] => IP_ADDRESS_1
[SERVER_PORT] => 80
[REMOTE_ADDR] => IP_ADDRESS_2
[DOCUMENT_ROOT] => /path/to/document_root/htdocs
[SERVER_ADMIN] => [email protected]
[SCRIPT_FILENAME] => /path/to/document_root/htdocs/test.php
[REMOTE_PORT] => 49178
[GATEWAY_INTERFACE] => CGI/1.1
[SERVER_PROTOCOL] => HTTP/1.1
[REQUEST_METHOD] => GET
[QUERY_STRING] =>
[REQUEST_URI] => /test.php
[SCRIPT_NAME] => /test.php
[PHP_SELF] => /test.php
[REQUEST_TIME] => 1292273758
)
Как вы можете видеть, SERVER_PORT - 80, а $_SERVER ['HTTPS'] не установлен. Согласно документам PHP, я думал, что он должен быть установлен на непустое значение, если PHP script доступен через HTTPS (что я и делаю).
Любая идея, что происходит? Я просто веб-разработчик - я не управляю этим сервером, но мой администратор сервера сообщает мне, что все работает, но я хотел бы знать, почему $_SERVER ['SERVER_PORT'] возвращает 80 вместо 443 при просмотре URL-адреса HTTPS.
EDIT: Я редактировал приведенный выше пример, чтобы проиллюстрировать мои результаты при печати всей переменной $_SERVER.
РЕДАКТИРОВАТЬ 2: Попытка https://my.example.com:443/test.php, как предложено в комментариях ниже, делает то же самое - SERVER_PORT 80 и HTTPS не задано (в частности, этот URL перенаправляется на https://my.example.com/test.php).
РЕДАКТИРОВАТЬ 3: Хорошо, я опубликовал то, что, по моему мнению, является ответом на это ниже (TL; DR: перемещение директив SSL внутри директивы VirtualHost и изменение этой директивы для ссылки на мой сайт с использованием это IP-адрес, а не подстановочный знак, по-видимому, разрешил проблему).