coderius/yii2-geo-ip 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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

Latest Stable Version Total Downloads Latest Unstable Version License Monthly Downloads

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-04-17