php 获取 ip 信息

byteweaver
• 阅读 4989

PHP 获取 ip 地址信息之前用过新浪/淘宝的接口,但如果新浪/淘宝接口出问题就没法用了,而且网络获取也慢.
今天介绍一个开源的geoip

淘宝接口

$ip = file_get_contents('http://ip.taobao.com/service/getIpInfo.php?ip=180.149.132.47');
print_r(json_decode($ip, 1));
Array
(
    [code] => 0
    [data] => Array
        (
            [country] => 中国
            [country_id] => CN
            [area] => 华北
            [area_id] => 100000
            [region] => 北京市
            [region_id] => 110000
            [city] => 北京市
            [city_id] => 110100
            [county] => 
            [county_id] => -1
            [isp] => 电信
            [isp_id] => 100017
            [ip] => 180.149.132.47
        )

)

纯真 IP 数据库

// 先下文件 QQWry.Dat http://www.cz88.net/fox/  http://update.cz88.net/soft/setup.zip
$IpLocation = new IpLocation('qqwry/QQWry.Dat');
$client = $IpLocation->getlocation('180.149.132.47');

安装 geoip

curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/bin/composer
chmod +x composer
composer require geoip2/geoip2:~2.0

使用

require_once 'vendor/autoload.php';
use GeoIp2\Database\Reader;
$reader = new Reader('GeoIP2-City.mmdb');
$record = $reader->city('180.149.132.47');// 百度 ip
dump($record);// dump 来自 laravel 

City {#1899 ▼
  #city: City {#1908 ▶}
  #location: Location {#1909 ▶}
  #postal: Postal {#1910 ▶}
  #subdivisions: array:1 [▶]
  #continent: Continent {#1902 ▶}
  #country: Country {#1903 ▶}
  #locales: array:1 [▶]
  #maxmind: MaxMind {#1904 ▶}
  #registeredCountry: Country {#1905 ▶}
  #representedCountry: RepresentedCountry {#1906 ▶}
  #traits: Traits {#1907 ▶}
  #raw: array:7 [▼
    "city" => array:2 [▼
      "geoname_id" => 1816670
      "names" => array:8 [▼
        "de" => "Peking"
        "en" => "Beijing"
        "es" => "Pekín"
        "fr" => "Pékin"
        "ja" => "北京市"
        "pt-BR" => "Pequim"
        "ru" => "Пекин"
        "zh-CN" => "北京"
      ]
    ]
    "continent" => array:3 [▼
      "code" => "AS"
      "geoname_id" => 6255147
      "names" => array:8 [▼
        "de" => "Asien"
        "en" => "Asia"
        "es" => "Asia"
        "fr" => "Asie"
        "ja" => "アジア"
        "pt-BR" => "Ásia"
        "ru" => "Азия"
        "zh-CN" => "亚洲"
      ]
    ]
    "country" => array:3 [▼
      "geoname_id" => 1814991
      "iso_code" => "CN"
      "names" => array:8 [▼
        "de" => "China"
        "en" => "China"
        "es" => "China"
        "fr" => "Chine"
        "ja" => "中国"
        "pt-BR" => "China"
        "ru" => "Китай"
        "zh-CN" => "中国"
      ]
    ]
    "location" => array:4 [▼
      "accuracy_radius" => 50
      "latitude" => 39.9289
      "longitude" => 116.3883
      "time_zone" => "Asia/Shanghai"
    ]
    "registered_country" => array:3 [▼
      "geoname_id" => 1814991
      "iso_code" => "CN"
      "names" => array:8 [▼
        "de" => "China"
        "en" => "China"
        "es" => "China"
        "fr" => "Chine"
        "ja" => "中国"
        "pt-BR" => "China"
        "ru" => "Китай"
        "zh-CN" => "中国"
      ]
    ]
    "subdivisions" => array:1 [▼
      0 => array:3 [▼
        "geoname_id" => 2038349
        "iso_code" => "11"
        "names" => array:3 [▼
          "en" => "Beijing"
          "fr" => "Municipalité de Pékin"
          "zh-CN" => "北京市"
        ]
      ]
    ]
    "traits" => array:1 [▼
      "ip_address" => "180.149.132.47"
    ]
  ]
}

print($record->country->isoCode . "\n"); // 'CN'
print($record->country->name . "\n"); // 'China'
print($record->country->names['zh-CN'] . "\n"); // '中国 '
print($record->mostSpecificSubdivision->name . "\n"); // 'Beijing'
print($record->mostSpecificSubdivision->isoCode . "\n"); // '11'
print($record->city->name . "\n"); // 'Beijing '
print($record->location->latitude . "\n"); // 39.9289
print($record->location->longitude . "\n"); // 116.3883

ip2region

php binding/php/testSearcher ./data/ip2region.db
p2region>> 101.105.35.57
2163|中国|华南|广东省|深圳市|鹏博士 in 0.02295 millseconds

公众号:苏生不惑

php 获取 ip 信息

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
6个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KaliTools说明书+BurpSuit实战指南+SQL注入知识库+国外渗透报告
!(https://oscimg.oschina.net/oscnet/d1c876a571bb41a7942dd9752f68632e.gif"15254461546.gif")0X00KaliLinux Tools中文说明书!(https://oscimg.oschina.net/oscnet/
Wesley13 Wesley13
3年前
IP地址查询接口及调用方法
设计蜂巢IP地址查询接口:http://www.hujuntao.com/api/ip/ip.php腾讯IP地址查询接口:http://fw.qq.com/ipaddress新浪IP地址查询接口:http://int.dpool.sina.com.cn/iplookup/iplookup.php?formatjs搜狐I
Stella981 Stella981
3年前
PHP的前世今生
大家都知道,Facebook、淘宝等早期都是用PHP写的,在中国,PHP在百度、新浪、腾讯这三大互联网公司中应用比较多。自1995年由丹麦人RasmusLerdorf(雷斯莫斯·勒道夫) 创建 PHP 以来,PHP语言经历了激烈的演进。PHP/FI1995年_摘要:用Perl写的小工具_PHP继承自一个老的工程,名叫P
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Pyhon批量获取淘宝商品详情数据方法
淘宝是一个网上购物平台,售卖各类商品,包括服装、鞋类、家居用品、美妆产品、电子产品等。要获取淘宝天猫商品详情SKU详细数据,您可以通过开放平台的接口或者直接访问淘宝天猫商城的网页来获取商品详情Sku信息。以下是两种常用方法的介绍:1.通过淘宝开放平台接口获