PHP获取客户端IP地址的方法

作者:萧钧 时间:2013-08-26 分类:wordpress知识 评论:1 条 浏览:2915

前段时间把网站公告改成了一个问候区,这两天有人跟我要代码,其实很简单没啥难度,就用到一个PHP函数——getenv。这个函数的作用就是获取环境变量。客户端IP地址的环境变量“REMOTE_ADDR,所以获取客户端IP地址的代码就是getenv(‘REMOTE_ADDR’); 。获得客户端IP地址后,使用百度的API获取IP地址的物理地址及运营商信息。

php get ip thumb PHP获取客户端IP地址的方法

我用的全部代码如下:

   1:  <p>------======<strong> 本站公告 </strong>======------<br/>
   2:  <script type="text/javascript">
   3:  function welcome(){
   4:  now = new Date();
   5:  hour = now.getHours();
   6:  if(hour < 6){
   7:  t="凌晨好"
   8:  }else if(hour < 9){
   9:  t="早上好"
  10:  }else if(hour < 11){
  11:  t="上午好"
  12:  }else if(hour < 13){
  13:  t="中午好"
  14:  }else if(hour < 17){
  15:  t="下午好"
  16:  }else if(hour < 19){
  17:  t="傍晚好"
  18:  }else if(hour < 22){
  19:  t="晚上好"
  20:  }else {
  21:  t="午夜好"
  22:  }
  23:  return t;
  24:  }
  25:  document.write(welcome());
  26:  </script>
  27:  ,来自
  28:  <?php
  29:  $lips = getenv('REMOTE_ADDR');
  30:  $ipc = @file_get_contents('http://api.map.baidu.com/location/ip?ak=C46b8ffa650b91721b4b94f183cf85ec&ip='.$lips);
  31:  $iparr=explode("|",$ipc);
  32:  $gj=explode('"',$iparr[0]);
  33:  if($gj[3]="CN") $gj="中国";
  34:  $sf=$iparr[1];
  35:  $ss=$iparr[2];
  36:  switch ($iparr[4]){
  37:   case "CHINANET": $dx="中国电信";
  38:   break;
  39:   case "UNICOM": $dx="中国联通";
  40:   break;
  41:   case "CMNET": $dx="中国移动";
  42:   break;
  43:   case "CRTC": $dx="中国铁通";
  44:   break;
  45:   case "COLNET": $dx="有线通";
  46:   break;
  47:   case "CERNET": $dx="教育网";
  48:   break;
  49:   case "CNCGROUP": $dx="中国网通";
  50:   break;
  51:   default: $dx="未知电信运营商";
  52:   }
  53:   ?>
  54:   <script type="text/javascript">
  55:   function reconvert(str){
  56:   str = str.replace(/(\\u)(\w{4})/gi,function($0){
  57:   return (String.fromCharCode(parseInt((escape($0).replace(/(%5Cu)(\w{4})/g,"$2")),16))); });
  58:   str = str.replace(/(&#x)(\w{4});/gi,function($0){
  59:   return String.fromCharCode(parseInt(escape($0).replace(/(%26%23x)(\w{4})(%3B)/g,"$2"),16)); });
  60:   return str;}document.write("<a title=\"<?php echo $lips ?>\">");
  61:   document.write(reconvert("<?php echo $gj.$sf.$ss.'-'.$dx ?>"));
  62:   document.write("</a>");
  63:   </script>
  64:   的朋友。
  65:   </p>

我以前介绍过利用百度API实现IP定位的功能,参见”利用百度API实现IP定位获取实际地址“。最后介绍一下getenv函数,其实主要是能用到的环境变量。

在PHP中getenv(参数)函数是一个用于获取环境变量的函数,根据提供不同的参数可以获取不同的环境变量,具体如下:

“PHP_SELF”

当前正在执行脚本的文件名,与document root 相关。举例来说,在URL 地址为[url]http://example.com/test.php/foo.bar[/url] 的脚本中使用$_SERVER['PHP_SELF'] 将会得到/test.php/foo.bar 这个结果。__FILE__ 常量包含当前(例如包含)文件的绝对路径和文件名。

如果PHP 以命令行方式运行,该变量在PHP 4.3.0 之前无效。

“argv”

传递给该脚本的参数。当脚本运行在命令行方式时,argv 变量传递给程序C 语言样式的命令行参数。当调用GET 方法时,该变量包含请求的数据。

“argc”

包含传递给程序的命令行参数的个数(如果运行在命令行模式)。

“GATEWAY_INTERFACE”

服务器使用的CGI 规范的版本。例如,“CGI/1.1”。

“SERVER_NAME”

当前运行脚本所在服务器主机的名称。如果该脚本运行在一个虚拟主机上,该名称是由那个虚拟主机所设置的值决定。

“SERVER_SOFTWARE”

服务器标识的字串,在响应请求时的头信息中给出。

“SERVER_PROTOCOL”

请求页面时通信协议的名称和版本。例如,“HTTP/1.0”。

“REQUEST_METHOD”

访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。

注: 如果请求的方式是HEAD,PHP 脚本将在送出头信息后中止(这意味着在产生任何输出后,不再有输出缓冲)。

“REQUEST_TIME”

请求开始时的时间戳。从PHP 5.1.0 起有效。

“QUERY_STRING”

查询(query)的字符串(URL 中第一个问号? 之后的内容)。

“DOCUMENT_ROOT”

当前运行脚本所在的文档根目录。在服务器配置文件中定义。

“HTTP_ACCEPT”

当前请求的Accept: 头信息的内容。

“HTTP_ACCEPT_CHARSET”

当前请求的Accept-Charset: 头信息的内容。例如:“iso-8859-1,*,utf-8”。

“HTTP_ACCEPT_ENCODING”

当前请求的Accept-Encoding: 头信息的内容。例如:“gzip”。

“HTTP_ACCEPT_LANGUAGE”

当前请求的Accept-Language: 头信息的内容。例如:“en”。

“HTTP_CONNECTION”

当前请求的Connection: 头信息的内容。例如:“Keep-Alive”。

“HTTP_HOST”

当前请求的Host: 头信息的内容。

“HTTP_REFERER”

链接到当前页面的前一页面的URL 地址。不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改HTTP_REFERER。因此,这个变量不总是真实正确的。

“HTTP_USER_AGENT”

当前请求的User-Agent: 头信息的内容。该字符串表明了访问该页面的用户代理的信息。一个典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。也可以使用get_browser() 得到此信息。

“HTTPS”

如果脚本是通过HTTPS 协议被访问,则被设为一个非空的值。

“REMOTE_ADDR”

正在浏览当前页面用户的IP 地址。

“REMOTE_HOST”

正在浏览当前页面用户的主机名。反向域名解析基于该用户的REMOTE_ADDR。

注: 必须配置Web 服务器来建立此变量。例如Apache 需要在httpd.conf 中有HostnameLookups On。参见gethostbyaddr()。

“REMOTE_PORT”

用户连接到服务器时所使用的端口。

“SCRIPT_FILENAME”

当前执行脚本的绝对路径名。

注: 如果脚本在CLI 中被执行,作为相对路径,例如file.php 或../file.php,$_SERVER['SCRIPT_FILENAME'] 将包含用户指定的相对路径。

“SERVER_ADMIN”

该值指明了Apache 服务器配置文件中的SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。

“SERVER_PORT”

服务器所使用的端口。默认为“80”。如果使用SSL 安全连接,则这个值为用户设置的HTTP 端口。

“SERVER_SIGNATURE”

包含服务器版本和虚拟主机名的字符串。

“PATH_TRANSLATED”

当前脚本所在文件系统(不是文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。

注: PHP 4.3.2 之后,PATH_TRANSLATED 在Apache 2 SAPI 模式下不再和Apache 1 一样隐含赋值,而是若Apache 不生成此值,PHP 便自己生成并将其值放入SCRIPT_FILENAME 服务器常量中。这个修改遵守了CGI 规范,PATH_TRANSLATED 仅在PATH_INFO 被定义的条件下才存在。

Apache 2 用户可以使用httpd.conf 中的AcceptPathInfo On 来定义PATH_INFO。

“SCRIPT_NAME”

包含当前脚本的路径。这在页面需要指向自己时非常有用。__FILE__ 包含当前文件的绝对路径和文件名(例如包含文件)。

“REQUEST_URI”

访问此页面所需的URI。例如,“/index.html”。

“PHP_AUTH_DIGEST”

当作为Apache 模块运行时,进行HTTP Digest 认证的过程中,此变量被设置成客户端发送的“Authorization”HTTP 头内容(以便作进一步的认证操作)。

“PHP_AUTH_USER”

当PHP 运行在Apache 或IIS(PHP 5 是ISAPI)模块方式下,并且正在使用HTTP 认证功能,这个变量便是用户输入的用户名。

“PHP_AUTH_PW”

当PHP 运行在Apache 或IIS(PHP 5 是ISAPI)模块方式下,并且正在使用HTTP 认证功能,这个变量便是用户输入的密码。

标签:

相关推荐
更多

  1. Pingback: 防火板

加樊泽敏为微信好友