-
-
Notifications
You must be signed in to change notification settings - Fork 7
Home
A PHP IP Address Geolocation library to help you identify visitors geographical location. This component is Build with an eye to keeping it as lightweight and lookups as fast as possible. And there are no external requests being made during runtime. So, if you need to get your website visitor's country and you don't want to use any API then this is the best solution for you. The project include methods to quickly update the files providing ip ranges with the least possible human intervention.
php_curl, ziparchive (for install or update)
These instructions will get you a copy of the project up and running on your local machine.
To utilize GeoIPCountry, first import and require GeoIPCountry.php file in your project.
require_once 'GeoIPCountry.php'; $IP2Country = new \iriven\GeoIPCountry(); //Initialisation /*
- NOTE: Initialisation may take a while if GeoIP data directory is missing or is corrupted (some files missing).
- If so, it will download the last available zip package form software77 website and rebuild GeoIP data directory files,
- dont close the page until it finished. */ Getting Country code from given IP address:
$ip = '63.140.250.97'; $CountryCode = $IP2Country->resolve($ip); echo 'Country Code: '.$countryCode; Retrieving Country name:
Because one of my publications already deals with the recovery of a country's name from its ISO code. I chose in this project to limit myself to the only search of the country's ALPHA2 ISO code from a given ip address. So, to retrieve the country name (and much more), you must instantiate the "WorldCountriesDatas" class available form HERE, and pass the result of the previous command as follows:
$ip = '63.140.250.97'; $CountryName ='n/a'; $CountryCode = $IP2Country->resolve($ip); if(!$IP2Country->isReservedIP()) //isReservedIP() method called with no argument { require_once 'WorldCountriesDatas.php'; $DataProvider = new \Iriven\WorldCountriesDatas(); $CountryName = $DataProvider->getCountryName($CountryCode); } or as follows:
$ip = '63.140.250.97'; $CountryName ='n/a'; if(!$IP2Country->isReservedIP($ip)) //isReservedIP() method called with $ip as argument { $CountryCode = $IP2Country->resolve($ip); require_once 'WorldCountriesDatas.php'; $DataProvider = new \Iriven\WorldCountriesDatas(); $CountryName = $DataProvider->getCountryName($CountryCode); } Updating GeoIP datas:
$IP2Country->Admin()->updateDatabase(); /*
- NOTE: calling the Admin() method help enter in edit Mode;
- the command: $IP2Country->updateDatabase(); will have no effect */ Compatibility:
IPV4 IPV6 TODO:
Implement IPV6 Supports Authors
Alfred TCHONDJO - Project Initiator - iriven France License
This project is licensed under the GNU General Public License V3 - see the LICENSE file for details
Acknowledgments
This project uses GeoIp data by Software77, available from http://software77.net/geo-ip/?DL=2 Disclaimer
If you use this library in your project please add a backlink to this page by this code.
This Project Uses Alfred's TCHONDJO GeoIPCountry PHP Library.