IP2Location Laravel extension enables the user to find the country, region, city, coordinates, zip code, time zone, ISP, domain name, connection type, area code, weather, MCC, MNC, mobile brand name, elevation, usage type, IP address type and IAB advertising category from IP address using IP2Location database.
IP2Location Laravel extension enables the user to find the country, region, district, city, coordinates, zip code, time zone, ISP, domain name, connection type, area code, weather, MCC, MNC, mobile brand name, elevation, usage type, IP address type, IAB advertising category and ASN from IP address using IP2Location database. It has been optimized for speed and memory utilization.
Note: This extension works in Laravel 6, Laravel 7, Laravel 8, Laravel 9, Laravel 10 and Laravel 11.
Run the command: composer require ip2location/ip2location-laravel
to download the package into the Laravel platform.
IP2Location Laravel extension is able to query the IP address information from either BIN database or web service. This section will explain how to use this extension to query from BIN database and web service.
ip2location
in the database
directory.database/ip2location/
folder.php artisan make:controller TestController
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use IP2LocationLaravel; //use IP2LocationLaravel class
class TestController extends Controller
{
//Create a lookup function for display
public function lookup(){
//Try query the geolocation information of 8.8.8.8 IP address
$records = IP2LocationLaravel::get('8.8.8.8', 'bin');
echo 'IP Number : ' . $records['ipNumber'] . "<br>";
echo 'IP Version : ' . $records['ipVersion'] . "<br>";
echo 'IP Address : ' . $records['ipAddress'] . "<br>";
echo 'Country Code : ' . $records['countryCode'] . "<br>";
echo 'Country Name : ' . $records['countryName'] . "<br>";
echo 'Region Name : ' . $records['regionName'] . "<br>";
echo 'City Name : ' . $records['cityName'] . "<br>";
echo 'Latitude : ' . $records['latitude'] . "<br>";
echo 'Longitude : ' . $records['longitude'] . "<br>";
echo 'Area Code : ' . $records['areaCode'] . "<br>";
echo 'IDD Code : ' . $records['iddCode'] . "<br>";
echo 'Weather Station Code : ' . $records['weatherStationCode'] . "<br>";
echo 'Weather Station Name : ' . $records['weatherStationName'] . "<br>";
echo 'MCC : ' . $records['mcc'] . "<br>";
echo 'MNC : ' . $records['mnc'] . "<br>";
echo 'Mobile Carrier : ' . $records['mobileCarrierName'] . "<br>";
echo 'Usage Type : ' . $records['usageType'] . "<br>";
echo 'Elevation : ' . $records['elevation'] . "<br>";
echo 'Net Speed : ' . $records['netSpeed'] . "<br>";
echo 'Time Zone : ' . $records['timeZone'] . "<br>";
echo 'ZIP Code : ' . $records['zipCode'] . "<br>";
echo 'Domain Name : ' . $records['domainName'] . "<br>";
echo 'ISP Name : ' . $records['isp'] . "<br>";
echo 'Address Type : ' . $records['addressType'] . "<br>";
echo 'Category : ' . $records['category'] . "<br>";
echo 'District : ' . $records['district'] . "<br>";
echo 'ASN : ' . $records['asn'] . "<br>";
echo 'AS : ' . $records['as'] . "<br>";
}
}
Route::get('test', 'App\Http\Controllers\TestController@lookup');
config
directory.<?php
return [
'IP2LocationioAPIKey' => 'your_api_key', // Required. Your IP2Location.io API key.
'IP2LocationioLanguage' => 'en', // Optional. Refer to https://www.ip2location.io/ip2location-documentation for available languages.
];
Or save the following contents for IP2Location:
<?php
return [
'IP2LocationAPIKey' => 'your_api_key', // Required. Your IP2Location API key.
'IP2LocationPackage' => 'WS1', // Required. Choose the package you would like to use.
'IP2LocationUsessl' => false, // Optional. Use https or http.
'IP2LocationAddons' => [], // Optional. Refer to https://www.ip2location.com/web-service/ip2location for the list of available addons.
'IP2LocationLanguage' => 'en', // Optional. Refer to https://www.ip2location.com/web-service/ip2location for available languages.
];
php artisan make:controller TestController
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use IP2LocationLaravel; //use IP2LocationLaravel class
class TestController extends Controller
{
//Create a lookup function for display
public function lookup(){
//Try query the geolocation information of 8.8.8.8 IP address
$records = IP2LocationLaravel::get('8.8.8.8', 'ws');
echo '<pre>';
print_r($records);
echo '</pre>';
}
}
Route::get('test', 'App\Http\Controllers\TestController@lookup');
php artisan make:controller TestController
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use IP2LocationLaravel; //use IP2LocationLaravel class
class TestController extends Controller
{
//Create a lookup function for display
public function lookup(){
var_dump(IP2LocationLaravel::isIpv4('8.8.8.8'));echo '<br>';
var_dump(IP2LocationLaravel::isIpv6('2001:4860:4860::8888'));echo '<br>';
print_r(IP2LocationLaravel::ipv4ToDecimal('8.8.8.8'));echo '<br>';
print_r(IP2LocationLaravel::decimalToIpv4(134744072));echo '<br>';
print_r(IP2LocationLaravel::ipv6ToDecimal('2001:4860:4860::8888'));echo '<br>';
print_r(IP2LocationLaravel::decimalToIpv6('42541956123769884636017138956568135816'));echo '<br>';
print_r(IP2LocationLaravel::ipv4ToCidr('8.0.0.0', '8.255.255.255'));echo '<br>';
print_r(IP2LocationLaravel::cidrToIpv4('8.0.0.0/8'));echo '<br>';
print_r(IP2LocationLaravel::ipv6ToCidr('2002:0000:0000:1234:abcd:ffff:c0a8:0000', '2002:0000:0000:1234:ffff:ffff:ffff:ffff'));echo '<br>';
print_r(IP2LocationLaravel::cidrToIpv6('2002::1234:abcd:ffff:c0a8:101/64'));echo '<br>';
print_r(IP2LocationLaravel::compressIpv6('2002:0000:0000:1234:FFFF:FFFF:FFFF:FFFF'));echo '<br>';
print_r(IP2LocationLaravel::expandIpv6('2002::1234:FFFF:FFFF:FFFF:FFFF'));echo '<br>';
}
}
Route::get('test', 'App\Http\Controllers\TestController@lookup');
This library requires either IP2Location BIN data file or IP2Location API key to function. You may download the BIN data file at
For IP2Location API key, you can sign up IP2Location Web Service to get one free API key.
Use the IPv4 BIN file if you just need to query IPv4 addresses.
Use the IPv6 BIN file if you need to query BOTH IPv4 and IPv6 addresses.
Email: [email protected]
Website: https://www.ip2location.com