zoukankan      html  css  js  c++  java
  • JavaScript跨域获得用户的IPv6地址


        首先,要消除一个误区,就是用户在浏览器中输入一个URL,只能通过IPv4或者IPv6一种方式访问。

        而我想做的,就是让用户访问我的IPv4的域名的时候,同时显示出用户的IPv4和IPv6的地址。方法是在首页中加一段JavaScript代码,用户浏览器执行这段JS代码,访问我的IPv6的域名。

         注意: IPv4和IPv6的服务器可以在同一个机子的Apache中跑着!

        对JS比较了解的人应该知道,JS是禁止跨域访问的,至少在目前主流的浏览器中,是禁止使用的。查阅了半天资料,发现了有一种JSONP的方法,可以实现变相的一种跨域,不过需要服务器的PHP脚本和客户端的JS代码相互配合才行。

        要获得用户的IP地址,在PHP中,可以直接从环境变量中获取。直接贴代码:

    复制代码
     1 function getIP() /*获取客户端IP*/
     2    { 
     3      if (@$_SERVER["HTTP_X_FORWARDED_FOR"]) 
     4      $ip = $_SERVER["HTTP_X_FORWARDED_FOR"]; 
     5      else if (@$_SERVER["HTTP_CLIENT_IP"]) 
     6      $ip = $_SERVER["HTTP_CLIENT_IP"]; 
     7      else if (@$_SERVER["REMOTE_ADDR"]) 
     8      $ip = $_SERVER["REMOTE_ADDR"]; 
     9      else if (@getenv("HTTP_X_FORWARDED_FOR"))
    10      $ip = getenv("HTTP_X_FORWARDED_FOR"); 
    11      else if (@getenv("HTTP_CLIENT_IP")) 
    12      $ip = getenv("HTTP_CLIENT_IP"); 
    13      else if (@getenv("REMOTE_ADDR")) 
    14      $ip = getenv("REMOTE_ADDR"); 
    15      else 
    16      $ip = "Unknown"; 
    17      return $ip; 
    18    }
    复制代码

    这样的一段代码,放在服务器的脚本中被调用,用户通过IPv4的域名访问,就得到自己的IPv4地址,通过IPv6的域名访问,就得到自己的IPv6地址。

         现在要做跨域啦:

    在a.html中写这个,其中yourIpv6domin一定要填写自己的IPv6的域名,或者服务的IPv6地址。

    1 <script src="http://yourIpv6domin/getipaddress.js.php" type="text/javascript">
    2 alert(ipv6_address);
    3 </script>

    在getipaddress.js.php中写这个

       $ip=getIP();
       echo 
       "var ipv6_address ='$ip'; ";


    这样,用户就可以在访问Ipv4域名的a.html的时候,获得自己的IPv6地址。

    基本的原理就是这样,跨域应该还有其他的办法。

         

    如果需要转载,请附上连接:http://www.cnblogs.com/wpjsolo/archive/2011/12/15/crossdomin.html

  • 相关阅读:
    牛儿
    Tarjan算法
    There&nbsp;is&nbsp;no&nbsp;resul…
    Struts2+JQuery+Json登陆实例
    struts2+jquery+easyui+datagrid+j…
    Spring:JdbcTemplate使用指南
    使用Spring的jdbcTemplate进一步简…
    JDBC连接MySQL数据库及示例
    PLSQL导入/导出数据方法
    PLSQ创建用户L
  • 原文地址:https://www.cnblogs.com/sunscheung/p/4839446.html
Copyright © 2011-2022 走看看