Как распечатать текущий URL-адрес?

Я хочу распечатать текущий URL-адрес, но мой код не работает.

Я использую это в файле file.php

echo "http://".$_SERVER['HTTP_HOST'].$_SERVER['SCRIPT_NAME']; 

Когда я открываю URL-адрес http://sub.mydomain.com/file.php, он работает нормально, и он печатает "http://sub.mydomain.com/file.php"

Но если я удалю расширение .php, поэтому URL-адрес будет http://sub.mydomain.com/file , он напечатает "http://sub.mydomain.com/sub/file.php" что неверно.

Он печатает субдомен дважды, и я не знаю почему?

В моем файле .htaccess у меня есть переписывание, которое позволяет удалять расширения .php.

Любой, кто может / хочет помочь мне, пожалуйста? 🙂

Вам нужно $_SERVER['REQUEST_URI'] вместо $_SERVER['SCRIPT_NAME'] , cos $_SERVER['SCRIPT_NAME'] всегда даст вам файл, который работает в данный момент.

Из руководства:

SCRIPT_NAME: содержит путь текущего скрипта. Это полезно для страниц, которые должны указывать на себя. Константа __FILE__ содержит полный путь и имя файла текущего (т.е. включенного) файла. ,

Полагаю, это поможет вам полностью загрузить текущий URL.

 echo 'http://'. $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI']; 

Примечание: НЕ ЗНАЙТЕ НА HTTP_HOST , ИСПОЛЬЗУЙТЕ SERVER_NAME ВМЕСТО! ВИДЕТЬ: HTTP_HOST и SERVER_NAME

Предупреждение безопасности

Вы должны фильтровать (дезинфицировать) $_SERVER['REQUEST_URI'] если вы используете его в любом месте (для печати или хранения в базе данных), потому что это небезопасно.

 // ie: this could be harmfull /user?id=123%00%27<script.... 

Следовательно, всегда фильтруйте пользовательские входы перед их использованием. По крайней мере, используйте htmlspecialchars , htmlentities , strip_tags т. Д.

Или что-то вроде этого;

 function get_current_url($strip = true) { static $filter, $scheme, $host; if (!$filter) { // sanitizer $filter = function($input) use($strip) { $input = trim($input); if ($input == '/') { return $input; } // add more chars if needed $input = str_ireplace(["\0", '%00', "\x0a", '%0a', "\x1a", '%1a'], '', rawurldecode($input)); // remove markup stuff if ($strip) { $input = strip_tags($input); } // or any encoding you use instead of utf-8 $input = htmlspecialchars($input, ENT_QUOTES, 'utf-8'); return $input; }; $host = $_SERVER['SERVER_NAME']; $scheme = isset($_SERVER['REQUEST_SCHEME']) ? $_SERVER['REQUEST_SCHEME'] : ('http'. (($_SERVER['SERVER_PORT'] == '443') ? 's' : '')); } return sprintf('%s://%s%s', $scheme, $host, $filter($_SERVER['REQUEST_URI'])); } 
 $main_folder = str_replace('\\','/',dirname(__FILE__) ); $document_root = str_replace('\\','/',$_SERVER['DOCUMENT_ROOT'] ); $main_folder = str_replace( $document_root, '', $main_folder); if( $main_folder ) { $current_url = $_SERVER['REQUEST_SCHEME'].'://'.$_SERVER['SERVER_NAME']. '/' . ltrim( $main_folder, '/' ) . '/'; } else { $current_url = $_SERVER['REQUEST_SCHEME'].'://'.rtrim( $_SERVER['SERVER_NAME'], '/'). '/'; }