您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 12331|回复: 0
打印 上一主题 下一主题

[php学习资料] PHP获取来路域名

[复制链接]
跳转到指定楼层
楼主
发表于 2018-8-19 01:14:23 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. $url = $_SERVER["HTTP_REFERER"]; //获取完整的来路URL
    7 D3 W7 T" {. a8 |5 A% b: h

  2. $ z9 z- I: N; \7 L: L
  3. $str = str_replace("http://","",$url); //去掉http://
    8 L) L" S% B4 q& {+ b: L
  4. $strdomain = explode("/",$str); // 以“/”分开成数组
    1 P* M% e8 g/ R8 X' n1 e
  5. $domain = $strdomain[0]; //取第一个“/”以前的字符
      w3 W$ B$ E9 u+ P) `

  6. $ R6 M6 f7 k& u" B
  7. 用上面的方法才准确无误,如果你用PHP自带的函数就不对如:
    $ q, z- r/ S  l& J0 u- ?1 [
  8. $_SERVER['SERVER_NAME'] 这个函数它获取的是服务器域名
复制代码
  1. echo $_SERVER['HTTP_REFERER'];9 T+ I& p/ _3 ~. x; D
  2. 这个获取上个页面的url
    0 d4 }7 M$ J2 m! k
  3. 例如获得的是 $url = http://www.weisuyun.com/nihao.html' n  o" U# S3 }9 c
  4. 其他页面提交过来的不接受0 L' O5 N! o- ?  [' U
  5. if(strpos($url,'http://www.weisuyun.com')){  G3 e- K) [# j" n. V7 n. a
  6. echo '来源正确';9 J; R) |' L  q5 U) B" b# d
  7. ! [* P$ H( v* N, O
  8. }else{( G& `7 ^9 W" M6 h
  9. echo '来源不明';# k3 `* |# P9 T+ |+ E3 D
  10. }
    ( a4 t3 a+ D- N1 M' {
  11. strpos方法返回指定字符串所在指定字符串第一次出现的位置,没有则返回false,下标从0开始
复制代码
" m' \+ {/ f9 G! l; c, m; ~% R
5 p5 H; e$ P$ l" W

7 a" Y7 e$ g1 i, a6 C利用PHP获取访客IP、地区位置、浏览器及来源页面等信息
* m0 u3 B4 U5 W
* v# [2 R; b8 U8 N( K% g9 ^
2 m, ^. r( G" O+ v6 T4 ?" C

前言

本文中主要介绍了关于利用PHP获取访客IP、地区位置、浏览器及来源页面等信息的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:

不多说了,每个方法都注释了,可以直接用:

示例代码

  1. <?php5 t' v$ L. E( ?
  2. //这个类似用来获取访客信息的
    + O8 A# J# ]. B# l$ P3 v
  3. //方便统计+ X5 p1 g; S- A
  4. class visitorInfo3 Q; K( M. w& d8 |
  5. {% m3 `8 Q% X2 }/ \
  6. //获取访客ip
    , F6 F( G( ]& |  V
  7. public function getIp()
    6 T" a/ k3 r( ]2 u
  8. {( n$ o/ h$ F! J- u6 G
  9.   $ip=false;
    " B, R8 d: r( H
  10.   if(!empty($_SERVER["HTTP_CLIENT_IP"])){  G* ?  F. [+ L. u/ r4 r- s4 r
  11.    $ip = $_SERVER["HTTP_CLIENT_IP"];
    * Z3 @( u# n4 c) g; C6 N/ V$ j
  12.   }( J) i2 w! G2 R' {: q/ n
  13.   if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
    + {2 k6 y- m; Z
  14.    $ips = explode (", ", $_SERVER['HTTP_X_FORWARDED_FOR']);2 @* ^2 Q8 I8 B
  15.    if ($ip) { array_unshift($ips, $ip); $ip = FALSE; }' D* c* [' R3 f
  16.    for ($i = 0; $i < count($ips); $i++) {
    % x2 M, x8 w( y$ \# i
  17.     if (!eregi ("^(10│172.16│192.168).", $ips[$i])) {
    9 f+ J- r$ C6 W5 T) W! R, k" u6 V
  18.      $ip = $ips[$i];
    2 K* S: [* {6 Z9 e
  19.      break;
    # Y0 Z/ h; C2 ~  o2 C2 n
  20.     }
    ) Z+ x) S$ N( L" E( g
  21.    }# ?5 ~: y) L. n
  22.   }
      T. d# J' v, Z4 U1 q
  23.   return ($ip ? $ip : $_SERVER['REMOTE_ADDR']);0 g* I. n! ~  `* z% W* w" B- E
  24. }2 O. j) _) x0 j% ?" P8 X- f
  25. 4 Q- X: r% [! F% k' M3 A% |' f( i
  26. //根据ip获取城市、网络运营商等信息8 R7 s, r  G1 P$ ]4 O
  27. public function findCityByIp($ip){
    % X9 e( U3 F, M, L
  28.   $data = file_get_contents('http://ip.taobao.com/service/getIpInfo.php?ip='.$ip);- C& A1 _2 @5 s; d1 h; B1 c
  29.   return json_decode($data,$assoc=true);
    3 s/ Z6 m5 z0 `& F% b( {
  30. }: `$ ^7 H2 g+ T' H' s1 f

  31. : A1 m; ^# j4 D
  32. //获取用户浏览器类型
    " B$ \! h  C9 T! |. z* p( x. U
  33. public function getBrowser(){
      t, q( F" o* }+ f
  34.   $agent=$_SERVER["HTTP_USER_AGENT"];/ m# @2 y' u1 A; _( P/ N
  35.   if(strpos($agent,'MSIE')!==false || strpos($agent,'rv:11.0')) //ie11判断& V) [" P! m( B7 n. V
  36.    return "ie";
    - k5 k4 E6 A/ D" N4 X' D
  37.   else if(strpos($agent,'Firefox')!==false)1 s6 w) F3 f0 j1 N7 K$ i
  38.    return "firefox";
    ! T/ Y% ]8 B$ p7 y7 Z0 j1 f1 n$ I
  39.   else if(strpos($agent,'Chrome')!==false)( T' c) W. [: }
  40.    return "chrome";/ M& c+ T2 C- `6 M+ p
  41.   else if(strpos($agent,'Opera')!==false)
    / m  F$ i3 M0 e# Q$ H
  42.    return 'opera';' w( {8 ~- r/ {1 K7 g
  43.   else if((strpos($agent,'Chrome')==false)&&strpos($agent,'Safari')!==false)
    " ]" P& w; N- X# |/ @
  44.    return 'safari';
    ) ]2 v/ R4 ?( n! W6 `: }( [
  45.   else1 e3 h- R' Q0 a' D
  46.    return 'unknown';
    3 T# V" L! L) ?
  47. }' W% V- ]+ Z" \
  48. 9 a7 P  X' O* z7 q0 Y, J& f
  49. //获取网站来源
    $ ]- E  d& t$ I
  50. public function getFromPage(){
    ( `9 C! e9 [. ~$ K+ h$ I& Q- N
  51.   return $_SERVER['HTTP_REFERER'];. R+ X7 E5 g( G
  52. }
    / Y# J& e( F8 [0 l# z2 n( M

  53. ( W5 A# X) T, [
  54. }
复制代码

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

4 ]) c; n8 ?5 b% `  O5 u
# |  G& i: R9 L( f
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 21:15 , Processed in 0.105308 second(s), 20 queries .

Copyright © 2001-2024 Powered by cncml! X3.2. Theme By cncml!