IP2Location Yii Extension - Get geolocation data from IP address

This extension use IP2Location BIN database to lookup visitor geographical location by their IP address. You can easily translate the IP address into country code, country name, region name, city name, latitude & longitude, time zone, usage type and so on.

The extension works well with IP2Location LITE (free database) or IP2Location Database (commercial database). IP2Location database is updated monthly. You can get the latest database from www.ip2location.com (Commercial version) or lite.ip2location.com (Free version).

Download IP2Location Yii Extension (for Yii version 1.x)
For Yii version 2.x, please view the below section for the installation guide.

 

Installation (version 1.x)
  1. Download the Yii Extension package.
  2. Extract this package to protected/extensions
  3. Download IP2Location free database for LITE version (free) or commercial version.
  4. Add following lines into main.php configuration file:
  5. 'components' => array(
    				...
    				'ip2location' => array(
    				'class' => 'application.extensions.ip2location.Geolocation',
    				'database' => 'C:\path\to\ip2location\IP2LOCATION-LITE-DB1.BIN',
    				'mode' => 'FILE_IO',
    				),
    				...
    				),
  6. You're done.

 

Sample Codes (version 1.x)

Use the following methods to retrieve geolocation information. If $ip not provided, value from CHttpRequest::getUserHostAddress() will be used.

			$countryCode = Yii::app()->IP2LOCATION->getCountryCode($ip);
			$countryName = Yii::app()->IP2LOCATION->getCountryName($ip);
			$regionName = Yii::app()->IP2LOCATION->getRegionName($ip);
			$cityName = Yii::app()->IP2LOCATION->getCityName($ip);
			$latitude = Yii::app()->IP2LOCATION->getLatitude($ip);
			$longitude = Yii::app()->IP2LOCATION->getLongitude($ip);
			$isp = Yii::app()->IP2LOCATION->getISP($ip);
			$domainName = Yii::app()->IP2LOCATION->getDomainName($ip);
			$zipCode = Yii::app()->IP2LOCATION->getZIPCode($ip);
			$timeZone = Yii::app()->IP2LOCATION->getTimeZone($ip);
			$netSpeed = Yii::app()->IP2LOCATION->getNetSpeed($ip);
			$iddCode = Yii::app()->IP2LOCATION->getIDDCode($ip);
			$areaCode = Yii::app()->IP2LOCATION->getAreaCode($ip);
			$weatherStationCode = Yii::app()->IP2LOCATION->getWeatherStationCode($ip);
			$weatherStationName = Yii::app()->IP2LOCATION->getWeatherStationName($ip);
			$mcc = Yii::app()->IP2LOCATION->getMCC($ip);
			$mnc = Yii::app()->IP2LOCATION->getMNC($ip);
			$mobileCarrierName = Yii::app()->IP2LOCATION->getMobileCarrierName($ip);
			$elevation = Yii::app()->IP2LOCATION->getElevation($ip);
			$usageType = Yii::app()->IP2LOCATION->getUsageType($ip);
			

 

Installation (version 2.x)

Inside the Yii 2.0 installation guide, it's recommended to use the composer for the installation. Thefore, in the below tutorials, we assume that you already have the composer installed in your environment.

Install the IP2Location PHP library using composer.

php composer.phar require ip2location/ip2location-php:7.*
Or, add the following line into the require section and execute php composer.phar update
"ip2location/ip2location-php": "7.*"

Sample Codes (version 2.x)

Use the following methods to retrieve geolocation information.

/*
   Cache whole database into system memory and share among other scripts & websites
   WARNING: Please make sure your system have sufficient RAM to enable this feature
*/
// $db = new \IP2Location\Database('path_to/IP-COUNTRY-SAMPLE.BIN', \IP2Location\Database::MEMORY_CACHE);

/*
   Cache the database into memory to accelerate lookup speed
   WARNING: Please make sure your system have sufficient RAM to enable this feature
*/
// $db = new \IP2Location\Database('path_to//IP-COUNTRY-SAMPLE.BIN', \IP2Location\Database::MEMORY_CACHE);


/*
	Default file I/O lookup
*/
$db = new \IP2Location\Database('path_to/IP-COUNTRY-SAMPLE.BIN', \IP2Location\Database::FILE_IO);

$records = $db->lookup('8.8.8.8', \IP2Location\Database::ALL);

echo 'IP Number             : ' . $records['ipNumber'] . "\n";
echo 'IP Version            : ' . $records['ipVersion'] . "\n";
echo 'IP Address            : ' . $records['ipAddress'] . "\n";
echo 'Country Code          : ' . $records['countryCode'] . "\n";
echo 'Country Name          : ' . $records['countryName'] . "\n";
echo 'Region Name           : ' . $records['regionName'] . "\n";
echo 'City Name             : ' . $records['cityName'] . "\n";
echo 'Latitude              : ' . $records['latitude'] . "\n";
echo 'Longitude             : ' . $records['longitude'] . "\n";
echo 'Area Code             : ' . $records['areaCode'] . "\n";
echo 'IDD Code              : ' . $records['iddCode'] . "\n";
echo 'Weather Station Code  : ' . $records['weatherStationCode'] . "\n";
echo 'Weather Station Name  : ' . $records['weatherStationName'] . "\n";
echo 'MCC                   : ' . $records['mcc'] . "\n";
echo 'MNC                   : ' . $records['mnc'] . "\n";
echo 'Mobile Carrier        : ' . $records['mobileCarrierName'] . "\n";
echo 'Usage Type            : ' . $records['usageType'] . "\n";
echo 'Elevation             : ' . $records['elevation'] . "\n";
echo 'Net Speed             : ' . $records['netSpeed'] . "\n";
echo 'Time Zone             : ' . $records['timeZone'] . "\n";
echo 'ZIP Code              : ' . $records['zipCode'] . "\n";
echo 'Domain Name           : ' . $records['domainName'] . "\n";
echo 'ISP Name              : ' . $records['isp'] . "\n";
			
Sample IP2Location Databases (BIN)

The following evaluation copy of the database file has limited range of IP address information compare to commercial. For evaluation purpose, you can query IP addresses from 0.0.0.0-99.255.255.255 (IPv4) or 2A04:0:0:0:0:0:0:0-2A04:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF (IPv6).

Sample Packages IPv4 IPv6
IP2Location DB1 Sample Bin File469.88 kB73.62 kB
IP2Location DB2 Sample Bin File38.56 MB98.25 kB
IP2Location DB3 Sample Bin File18.59 MB83.64 kB
IP2Location DB4 Sample Bin File55.23 MB106.02 kB
IP2Location DB5 Sample Bin File29.55 MB89.62 kB
IP2Location DB6 Sample Bin File66.06 MB109.74 kB
IP2Location DB7 Sample Bin File61.18 MB115.26 kB
IP2Location DB8 Sample Bin File72.27 MB119.08 kB
IP2Location DB9 Sample Bin File34.62 MB91.86 kB
IP2Location DB10 Sample Bin File78.32 MB122.97 kB
IP2Location DB11 Sample Bin File35.35 MB92.44 kB
IP2Location DB12 Sample Bin File78.86 MB123.76 kB
IP2Location DB13 Sample Bin File33.92 MB90.82 kB
IP2Location DB14 Sample Bin File80.28 MB124.37 kB
IP2Location DB15 Sample Bin File38.43 MB96.03 kB
IP2Location DB16 Sample Bin File85.19 MB129.27 kB
IP2Location DB17 Sample Bin File41.61 MB97.87 kB
IP2Location DB18 Sample Bin File93.15 MB137.92 kB
IP2Location DB19 Sample Bin File75.10 MB119.78 kB
IP2Location DB20 Sample Bin File95.71 MB139.09 kB
IP2Location DB21 Sample Bin File42.24 MB98.41 kB
IP2Location DB22 Sample Bin File100.27 MB141.85 kB
IP2Location DB23 Sample Bin File75.70 MB120.75 kB
IP2Location DB24 Sample Bin File101.21 MB142.79 kB