获取当前的网址 php,PHP获取当前页面完整网址URL

PHP是通过$_SERVER预定义变量获取当前页面完整URL的,$_SERVER是一个包含头信息、路径、文件位置的数组,它是由web服务器创建的,如果你用命令行方式运行PHP,那么$_SERVER完全无效。

对$_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。

$_SERVER[ 'PHP_AUTH_USER' ] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户名。

$_SERVER[ 'PHP_AUTH_PW' ] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码。

$_SERVER[ 'AUTH_TYPE' ] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是认证的类型。

注意:SERVER_NAME 和HTTP_HOST的区别(非80端口时HTTP_HOST = SERVER_NAME : SERVER_PORT)

常见的元素也就如上加粗部分,利用它们就可以很容易获取完整的url。

function get_page_url(){

$url = (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443') ? 'https://' : 'http://';

$url .= $_SERVER['HTTP_HOST'];

$url .= isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : urlencode($_SERVER['PHP_SELF']) . '?' . urlencode($_SERVER['QUERY_STRING']);

return $url;

}

echo get_page_url();

?>

说明:

$_SERVER

[

'REQUEST_URI'

]只是以apache作为web服务器才有效,如果不存在,应该

$_SERVER

[

'PHP_SELF'

]) .

'?'

.

$_SERVER

[

'QUERY_STRING'

]来获取,当然是用urlencode可以防止恶意url。

PS:如果用javascript获取url就简单多了:

document.write(this.location.href);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值