可能是一个微不足道的问题,但我正在寻找一种方法来说明网站网址的根源,例如:http://localhost/some/folder/containing/something/here/or/there
应该返回http://localhost/
我知道有$_SERVER['DOCUMENT_ROOT']
但这不是我想要的。
我确信这很容易,但我一直在阅读:This post试图找出我应该使用或致电的内容。
想法?
我所遇到的另一个问题是 - 答案是什么?将在http://subsite.localhost/some/folder/containing/something/here/or/there
这样的网站上工作,所以我的最终结果是http://subsite.localhost/
答案 0 :(得分:45)
$root = (!empty($_SERVER['HTTPS']) ? 'https' : 'http') . '://' . $_SERVER['HTTP_HOST'] . '/';
如果您对当前脚本的方案和主机感兴趣。
否则,parse_url(),如已建议的那样。 e.g。
$parsedUrl = parse_url('http://localhost/some/folder/containing/something/here/or/there');
$root = $parsedUrl['scheme'] . '://' . $parsedUrl['host'] . '/';
如果您对路径之前的其他网址组件(例如凭据)也感兴趣,您还可以在完整网址上使用strstr(),并将“path”作为指针,例如
$url = 'http://user:pass@localhost:80/some/folder/containing/something/here/or/there';
$parsedUrl = parse_url($url);
$root = strstr($url, $parsedUrl['path'], true) . '/';//gives 'http://user:pass@localhost:80/'
答案 1 :(得分:10)
另一种简单的方法:
<?php
$hostname = getenv('HTTP_HOST');
echo $hostname;
(PHP 4,PHP 5)
getenv - 获取环境变量的值
答案 2 :(得分:7)
此PHP函数返回完整路径的真实URL。
function pathUrl($dir = __DIR__){
$root = "";
$dir = str_replace('\\', '/', realpath($dir));
//HTTPS or HTTP
$root .= !empty($_SERVER['HTTPS']) ? 'https' : 'http';
//HOST
$root .= '://' . $_SERVER['HTTP_HOST'];
//ALIAS
if(!empty($_SERVER['CONTEXT_PREFIX'])) {
$root .= $_SERVER['CONTEXT_PREFIX'];
$root .= substr($dir, strlen($_SERVER[ 'CONTEXT_DOCUMENT_ROOT' ]));
} else {
$root .= substr($dir, strlen($_SERVER[ 'DOCUMENT_ROOT' ]));
}
$root .= '/';
return $root;
}
在此文件中调用pathUrl:http://example.com/shop/index.php
#index.php
echo pathUrl();
//http://example.com/shop/
使用别名:http://example.com/alias-name/shop/index.php
#index.php
echo pathUrl();
//http://example.com/alias-name/shop/
对于子目录:http://example.com/alias-name/shop/inc/config.php
#config.php
echo pathUrl(__DIR__ . '/../');
//http://example.com/alias-name/shop/
答案 3 :(得分:1)
您可以使用Define
保存define.php
包含,以便下次在其他项目中使用
这是PROTOCOL
DOMAIN
PORT
SITE_ROOT
和SITE PATH
**
* domain
* ex: localhost, maskphp.com, demo.maskphp.com,...
*/
define('DOMAIN', isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : $_SERVER['SERVER_NAME']);
/**
* protocol
* ex: http, https,...
*/
define('PROTOCOL', isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'] === 'on' || $_SERVER['HTTPS'] === 1)
|| isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] === 'https' ? 'https' : 'http');
/**
* port
* ex: 80, 8080,...
*/
define('PORT', $_SERVER['SERVER_PORT']);
/**
* site path
* ex: http://localhost/maskphp/ -> /maskphp/
*/
define('SITE_PATH', preg_replace('/index.php$/i', '', $_SERVER['PHP_SELF']));
/**
* site root
* ex: http://maskgroup.com, http://localhost/maskphp/,...
*/
define('SITE_ROOT', PROTOCOL . '://' . DOMAIN . (PORT === '80' ? '' : ':' . PORT) . SITE_PATH);
您可以调试以查看结果
答案 4 :(得分:0)
您可以preg_split
第一个/
处的网址 - 字符:
function rootUrl($url) {
$urlParts = preg_split('#(?<!/)/(?!/)#', $url, 2);
return $urlParts[0] != '' ? $urlParts[0] . '/' : '';
}
// examples:
echo rootUrl('http://user@www.example.com/path/to/file?query=string');
// output: http://user@www.example.com/
echo rootUrl('https://www.example.com/');
// output: https://www.example.com/
echo rootUrl('https://www.example.com');
// output: https://www.example.com/
echo rootUrl('example.com/path/to/file');
// output: example.com/
echo rootUrl('/path/to/file');
// output: [empty]
echo rootUrl('');
// output: [empty]
如果第一部分不为空,函数rootUrl($url)
将在第一个$url
- 字符加上尾随/
之前返回给定字符串/
的一部分。对于以/
(相对URL)开头的URL,将返回空字符串。