IP2Location IP Geolocation PHP Module

This IP Geolocation PHP module allows user to find the IP geolocation information about an IP address such as country codes, country name, region, district, city, coordinates, ZIP code, ISP, domain name, timezone, connection speed, IDD code, area code, weather station code, weather station name, MCC, MNC, mobile brand name, elevation, usage type, address type, IAB category and ASN that any IP address or host name originates from. It has been optimized for speed and memory utilization. Developers can use our IP geolocation API to query all IP2Location™ binary databases for IPv4 and IPv6 address.

Installation
  1. Run the command:
    composer require ip2location/ip2location-php

    Note: You just need to include the below code in order to use the library.
    require 'vendor/autoload.php';
Sample Codes
<?php
require 'vendor/autoload.php';

/*
   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('./data/IP-COUNTRY-REGION-CITY-LATITUDE-LONGITUDE-ZIPCODE-TIMEZONE-ISP-DOMAIN-NETSPEED-AREACODE-WEATHER-MOBILE-ELEVATION-USAGETYPE-ADDRESSTYPE-CATEGORY-DISTRICT-ASN-SAMPLE.BIN', \IP2Location\Database::SHARED_MEMORY);
/*
   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('./data/IP-COUNTRY-REGION-CITY-LATITUDE-LONGITUDE-ZIPCODE-TIMEZONE-ISP-DOMAIN-NETSPEED-AREACODE-WEATHER-MOBILE-ELEVATION-USAGETYPE-ADDRESSTYPE-CATEGORY-DISTRICT-ASN-SAMPLE.BIN', \IP2Location\Database::MEMORY_CACHE);


/*
	Default file I/O lookup
*/
$db = new \IP2Location\Database('./data/IP-COUNTRY-REGION-CITY-LATITUDE-LONGITUDE-ZIPCODE-TIMEZONE-ISP-DOMAIN-NETSPEED-AREACODE-WEATHER-MOBILE-ELEVATION-USAGETYPE-ADDRESSTYPE-CATEGORY-DISTRICT-ASN-SAMPLE.BIN', \IP2Location\Database::FILE_IO);

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

echo '<pre>';
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";
echo 'Address Type          : ' . $records['addressType'] . "\n";
echo 'Category              : ' . $records['category'] . "\n";
echo 'District              : ' . $records['district'] . "\n";
echo 'ASN                   : ' . $records['asn'] . "\n";
echo 'AS                    : ' . $records['as'] . "\n";
echo '</pre>';

// Web Service
$ws = new \IP2Location\WebService('demo', 'WS25', false);
$records = $ws->lookup('8.8.8.8', [
	'continent', 'country', 'region', 'city', 'geotargeting', 'country_groupings', 'time_zone_info',
], 'en');

echo '<pre>';
print_r($records);

echo 'Credit Remaining: ' . $ws->getCredit() . "\n";
echo '</pre>';

?>
Sample IP2Location Databases (BIN)
Sample Packages - BIN File IPv4 IPv6
IP2Location DB1 Download (1,018.00 kB) Download (1.06 MB)
IP2Location DB2 Download (24.56 MB) Download (25.21 MB)
IP2Location DB3 Download (21.04 MB) Download (21.16 MB)
IP2Location DB4 Download (43.75 MB) Download (43.89 MB)
IP2Location DB5 Download (31.62 MB) Download (31.79 MB)
IP2Location DB6 Download (53.83 MB) Download (54.01 MB)
IP2Location DB7 Download (48.56 MB) Download (48.74 MB)
IP2Location DB8 Download (58.91 MB) Download (59.13 MB)
IP2Location DB9 Download (36.40 MB) Download (36.59 MB)
IP2Location DB10 Download (64.31 MB) Download (64.59 MB)
IP2Location DB11 Download (37.14 MB) Download (37.35 MB)
IP2Location DB12 Download (65.01 MB) Download (65.25 MB)
IP2Location DB13 Download (34.73 MB) Download (34.94 MB)
IP2Location DB14 Download (66.24 MB) Download (66.48 MB)
IP2Location DB15 Download (40.32 MB) Download (40.56 MB)
IP2Location DB16 Download (70.48 MB) Download (70.77 MB)
IP2Location DB17 Download (42.11 MB) Download (42.38 MB)
IP2Location DB18 Download (77.76 MB) Download (78.15 MB)
IP2Location DB19 Download (61.61 MB) Download (61.83 MB)
IP2Location DB20 Download (80.21 MB) Download (80.61 MB)
IP2Location DB21 Download (43.89 MB) Download (44.22 MB)
IP2Location DB22 Download (84.22 MB) Download (84.76 MB)
IP2Location DB23 Download (62.04 MB) Download (62.23 MB)
IP2Location DB24 Download (85.37 MB) Download (85.76 MB)
IP2Location DB25 Download (87.34 MB) Download (87.79 MB)
IP2Location DB26 Download (93.86 MB) Download (94.38 MB)
Pop Up Box

Discover Your User Locations

Retrieve geolocation data for FREE now!