coderius/yii2-geo-ip
最新稳定版本:1.0.5.1
Composer 安装命令:
composer require coderius/yii2-geo-ip
包简介
Yii 2 GeoIP extension. Returns country, city, lat, lng of current or specified IP (uses MaxMind's GeoIP2 databases)
README 文档
README
This extension allows you to get geo data by ip address.
Currently available:
- All fields of the database Maxmind
Install
Run
$ php composer.phar require coderius/yii2-geo-ip "~1.0"
Or equal
$ composer require coderius/yii2-geo-ip "~1.0"
OR
add to your composer.json
{
"require": {
"coderius/yii2-geo-ip": "~1.0"
}
}
and run
$ php composer update
Usage
Component registration in app config
<?php $config = [ ... 'components' => [ 'geoip' => ['class' => 'coderius\geoIp\GeoIP'], ] ... ];
somewhere in code
$ip = Yii::$app->geoip->ip(); // current user ip $ip = Yii::$app->geoip->ip(null, false);// current user ip without catche $ip = Yii::$app->geoip->ip("208.113.83.165");
$ip = Yii::$app->geoip->ip("208.113.83.165")//or Yii::$app->geoip->ip() for current user $ip->city; // "San Francisco" $ip->country; // "United States" $ip->location->lng; // 37.7898 $ip->location->lat; // -122.3942 $ip->isoCode; //etc.
Provide a custom database (for example, if you own a licence)
<?php $config = [ ... 'components' => [ 'geoip' => [ 'class' => 'coderius\geoIp\GeoIP', 'dbPath' => Yii::getAlias('@example/maxmind/database/city.mmdb') ], ] ... ];
Advanced usage
To see all the available properties, you need to do the following:
```php
var_dump($ip->city);
var_dump($ip->continent);
var_dump($ip->country);
var_dump($ip->location);
var_dump($ip->postal);
var_dump($ip->registeredCountry);
var_dump($ip->subdivisions);
die;
The result can be like :
object(coderius\geoIp\City)#196 (2) { ["_geoname_id":"coderius\geoIp\City":private]=> int(5099836) ["_names":"coderius\geoIp\City":private]=> array(4) { ["en"]=> string(11) "Jersey City" ["ja"]=> string(24) "ジャージーシティ" ["ru"]=> string(21) "Джерси-Сити" ["zh-CN"]=> string(9) "泽西市" } } object(coderius\geoIp\Continent)#197 (3) { ["_code":"coderius\geoIp\Continent":private]=> string(2) "NA" ["_geoname_id":"coderius\geoIp\Continent":private]=> int(6255149) ["_names":"coderius\geoIp\Continent":private]=> array(8) { ["de"]=> string(11) "Nordamerika" ["en"]=> string(13) "North America" ["es"]=> string(13) "Norteamérica" ["fr"]=> string(17) "Amérique du Nord" ["ja"]=> string(15) "北アメリカ" ["pt-BR"]=> string(17) "América do Norte" ["ru"]=> string(31) "Северная Америка" ["zh-CN"]=> string(9) "北美洲" } } object(coderius\geoIp\Country)#198 (3) { ["_iso_code":"coderius\geoIp\Country":private]=> string(2) "US" ["_geoname_id":"coderius\geoIp\Country":private]=> int(6252001) ["_names":"coderius\geoIp\Country":private]=> array(8) { ["de"]=> string(3) "USA" ["en"]=> string(13) "United States" ["es"]=> string(14) "Estados Unidos" ["fr"]=> string(11) "États-Unis" ["ja"]=> string(21) "アメリカ合衆国" ["pt-BR"]=> string(14) "Estados Unidos" ["ru"]=> string(6) "США" ["zh-CN"]=> string(6) "美国" } } object(coderius\geoIp\Location)#199 (5) { ["_accuracy_radius":"coderius\geoIp\Location":private]=> int(1000) ["_latitude":"coderius\geoIp\Location":private]=> float(40.7209) ["_longitude":"coderius\geoIp\Location":private]=> float(-74.0468) ["_metro_code":"coderius\geoIp\Location":private]=> int(501) ["_time_zone":"coderius\geoIp\Location":private]=> string(16) "America/New_York" } object(coderius\geoIp\Postal)#200 (3) { ["_code":"coderius\geoIp\Postal":private]=> string(5) "07302" ["_geoname_id":"coderius\geoIp\Postal":private]=> NULL ["_names":"coderius\geoIp\Postal":private]=> array(0) { } } object(coderius\geoIp\RegisteredCountry)#201 (3) { ["_iso_code":"coderius\geoIp\RegisteredCountry":private]=> string(2) "US" ["_geoname_id":"coderius\geoIp\RegisteredCountry":private]=> int(6252001) ["_names":"coderius\geoIp\RegisteredCountry":private]=> array(8) { ["de"]=> string(3) "USA" ["en"]=> string(13) "United States" ["es"]=> string(14) "Estados Unidos" ["fr"]=> string(11) "États-Unis" ["ja"]=> string(21) "アメリカ合衆国" ["pt-BR"]=> string(14) "Estados Unidos" ["ru"]=> string(6) "США" ["zh-CN"]=> string(6) "美国" } } array(1) { [0]=> object(coderius\geoIp\Subdivision)#202 (3) { ["_iso_code":"coderius\geoIp\Subdivision":private]=> string(2) "NJ" ["_geoname_id":"coderius\geoIp\Subdivision":private]=> int(5101760) ["_names":"coderius\geoIp\Subdivision":private]=> array(7) { ["en"]=> string(10) "New Jersey" ["es"]=> string(12) "Nueva Jersey" ["fr"]=> string(10) "New Jersey" ["ja"]=> string(27) "ニュージャージー州" ["pt-BR"]=> string(12) "Nova Jérsia" ["ru"]=> string(19) "Нью-Джерси" ["zh-CN"]=> string(12) "新泽西州" } } }
When try to convert object to string like below, returned data from method _toString in equal classes objects:
echo $ip->city; echo "\n"; echo $ip->continent; echo "\n"; echo $ip->country; echo "\n"; echo $ip->location; echo "\n"; echo $ip->postal; echo "\n"; echo $ip->registeredCountry; echo "\n"; echo $ip->subdivisions[0]; echo "\n";
Output:
Jersey City North America United States -74.0468 40.7209 07302 United States New Jersey
For example get more info from city object:
$ip->city->GeonameId; $lang = Yii::$app->language; echo $ip->hasCity("names") ? $ip->city->names->$lang : "empty result..."; //or echo $ip->hasCity() ? $ip->city : "empty result...";//from _toString return $ip->city->names->en
This product includes GeoLite2 data created by MaxMind, available from http://www.maxmind.com
统计信息
- 总下载量: 2.02k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2018-04-17