如何从 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?的主要内容,如果未能解决你的问题,请参考以下文章
从 bigquery 开放数据库查询 IP 地理位置数据:geolite2
PHP - 如何在 MySql 中使用 GeoLite2 IP CSV 数据库?