如何从 GeoLite2 获取 isoCode?

Posted

技术标签:

【中文标题】如何从 GeoLite2 获取 isoCode?【英文标题】:How to get isoCode form GeoLite2? 【发布时间】:2017-01-15 21:28:09 【问题描述】:

我安装了 MaxMind 的 GeoLite2 和测试 php 文件:

<?php
require_once 'vendor/autoload.php';

use MaxMind\Db\Reader;
$ipAddress = '8.8.8.8';
$databaseFile = './GeoLite2-Country.mmdb';

$reader = new Reader($databaseFile);

print_r($reader->get($ipAddress));

$reader->close();

给我这些结果:

Array ( [continent] => Array ( [code] => NA [geoname_id] => 6255149 [names] => Array ( [de] => Nordamerika [en] => North America [es] => Norteamérica [fr] => Amérique du Nord [ja] => 北アメリカ [pt-BR] => América do Norte [ru] => Ð¡ÐµÐ²ÐµÑ€Ð½Ð°Ñ Ðмерика [zh-CN] => 北美洲 ) ) [country] => Array ( [geoname_id] => 6252001 [iso_code] => US [names] => Array ( [de] => USA [en] => United States [es] => Estados Unidos [fr] => États-Unis [ja] => アメリカåˆè¡†å›½ [pt-BR] => Estados Unidos [ru] => СШР[zh-CN] => 美国 ) ) [registered_country] => Array ( [geoname_id] => 6252001 [iso_code] => US [names] => Array ( [de] => USA [en] => United States [es] => Estados Unidos [fr] => États-Unis [ja] => アメリカåˆè¡†å›½ [pt-BR] => Estados Unidos [ru] => СШР[zh-CN] => 美国 ) ) ) 

我需要的只是 isoCode(在本例中为 US),有人知道如何从 GeoLite2 获取“US”而不是整个数组吗?

【问题讨论】:

【参考方案1】:

这就是MaxMind's database reader 的设计方式;它总是返回每次查找的完整记录。

您可以通过直接访问返回数组的元素来获取您感兴趣的特定信息:

// Fetch the database record for this IP address
$record = $reader->get($ipAddress);

// Output just the ISO country code ("US", in this case)
echo $record['country']['iso_code'] . PHP_EOL;

【讨论】:

谢谢你,Simon,我想你可以要求 iso_code。【参考方案2】:

修改你的例子:

<?php
require_once 'vendor/autoload.php';

use MaxMind\Db\Reader;
$ipAddress = '8.8.8.8';
$databaseFile = './GeoLite2-Country.mmdb';

$reader = new Reader($databaseFile);

$record = $reader->get($ipAddress);

print($record['country']['iso_code']);

$reader->close();

或者使用GeoIp2 API:

<?php
require_once 'vendor/autoload.php';
use GeoIp2\Database\Reader;


$reader = new Reader('/usr/local/share/GeoIP/GeoIP2-City.mmdb');


$record = $reader->city('8.8.8.8');
print($record->country->isoCode); 

【讨论】:

以上是关于如何从 GeoLite2 获取 isoCode?的主要内容,如果未能解决你的问题,请参考以下文章

如何从 geolite2 块中了解网络长度

从 bigquery 开放数据库查询 IP 地理位置数据:geolite2

PHP - 如何在 MySql 中使用 GeoLite2 IP CSV 数据库?

通过 Maxmind GeoLite2 Free 获取用户城市的本地化名称

“国家”级别的 GeoLite2 精度

如何在 Piwik 3.0.2(Motomo 旧版本)上安装 Geolite2?