This package is abandoned and no longer maintained. The author suggests using the geoip2/geoip2 package instead.


v1.17 2016-05-16 19:06 UTC

This package is auto-updated.

Last update: 2022-05-27 15:45:58 UTC


End of Life

MaxMind will be retiring the GeoIP Legacy databases at the end of May 2022. Until then, this library will only receive critical security and bug fixes. Support for this library will end completely with the last release of the legacy GeoIP databases.

We recommend that you upgrade to our GeoIP2 databases. You can read these from PHP with our GeoIP2 PHP API.

See our blog post for more information.


This module has no external dependencies. You only need a MaxMind GeoIP database.

Install via Composer

We recommend installing this package with Composer.

Download Composer

To download Composer, run in the root directory of your project:

curl -sS | php

You should now have the file composer.phar in your project directory.

Install Dependencies

Run in your project root:

php composer.phar require geoip/geoip:~1.16

You should now have the files composer.json and composer.lock as well as the directory vendor in your project directory. If you use a version control system, composer.json should be added to it.

Require Autoloader

After installing the dependencies, you need to require the Composer autoloader from your code:

require 'vendor/autoload.php';

Install without Composer

Place the '' file in the include_path as specified in your php.ini file or place it in the same directory as your PHP scripts.

IP Geolocation Usage

IP geolocation is inherently imprecise. Locations are often near the center of the population. Any location provided by a GeoIP database should not be used to identify a particular address or household.


Gets country name by hostname :


require 'vendor/autoload.php';

$gi = geoip_open("/usr/local/share/GeoIP/GeoIP.dat",GEOIP_STANDARD);

echo geoip_country_code_by_addr($gi, "") . "\t" .
     geoip_country_name_by_addr($gi, "") . "\n";
echo geoip_country_code_by_addr($gi, "") . "\t" .
     geoip_country_name_by_addr($gi, "") . "\n";


Memory Caching

To enable memory caching, pass GEOIP_SHARED_MEMORY or GEOIP_MEMORY_CACHE as the second argument of geoip_open.

GEOIP_SHARED_MEMORY requires php >= 4.0.4 compiled with --enable-shmop configure time. See ( In addition, you should call geoip_load_shared_mem before calling geoip_open. See sample_city.php for an example of shared memory caching.


This code is tested on PHP 5.4 and greater. Older versions of PHP may work.


For help with this API or our databases, please see our support page.

Copyright and License

This software is Copyright (c) 2016 by MaxMind, Inc.

This is free software, licensed under the GNU Lesser General Public License version 2.1 or later.


Thanks to Jim Winstead.