Laravel Cloud is here! Zero-config managed infrastructure for Laravel apps. Deploy now.

Publicip

Publicip stats

Downloads
6
Stars
5
Open Issues
0
Forks
0

View on GitHub →

Fast and reliable way to get your public IP address with PHP

PublicIP

A simple PHP library to get your public IP address reliably and fast.

This library uses dig or HTTP requests to obtain the public IP address of the current machine by utilizing publicly available whoami services.

It comes with an opinionated default configuration to use the fastest and most reliable fetchers and providers. However, it also includes a flexible API that allows you to use different fetchers and different providers.

πŸš€ Installation

composer require knotsphp/publicip

πŸ“š Usage

Easiest way to get the public IP address of the current machine is to use the PublicIP::get() method.

use KnotsPHP\PublicIP\Finders\{ PublicIP, PublicIPv4, PublicIPv6 };
 
$ipv4 = PublicIPv4::get(); // returns your IPv4
$ipv6 = PublicIPv6::get(); // returns your IPv6
$ipv4or6 = PublicIP::get(); // returns either IPv4 or IPv6

These methods return the IP address as a string or null if the fetcher fails. No exceptions are thrown.

If you want to use a specific fetcher, or a specific provider, you can use the PublicIPv4::finder()->fetch() method.

use KnotsPHP\PublicIP\Enums\DnsProvider;
use KnotsPHP\PublicIP\Fetchers\DigFetcher;
use KnotsPHP\PublicIP\Finders\PublicIPv4;
 
$ipv4 = PublicIPv4::finder()
->addFetcher((new DigFetcher())
->from(DnsProvider::OpenDNS)))
->fetch();

This method gives you more control, but you will need to manage exceptions on your own.

Advanced Usage

You can also use a Fetcher directly to get the IP address.

use KnotsPHP\PublicIP\Enums\DnsProvider;
use KnotsPHP\PublicIP\Enums\IpVersion;
use KnotsPHP\PublicIP\Fetchers\DigFetcher;
 
$ipv4 = (new DigFetcher)->from(DnsProvider::Cloudflare)->fetch(IpVersion::v4);

Note that this returns null instead of throwing an exception if the fetcher fails.

πŸ“š Use in command line

You can also use this library in the command line by using the publicip command.

It's recommended to install the library globally to use it in the command line.

composer global require knotsphp/publicip

Then you can use the publicip command to get the public IP address of the current machine.

# In your project directory
vendor/bin/publicip
 
# Globally installed
publicip
 
# To get the IPv4 address
publicip --ipv4
publicip -4
 
# To get the IPv6 address
publicip --ipv6
publicip -6

πŸƒ Performance

If you are sure that your machine has dig installed, you can speed up the process by setting the isSupported property to true.

It works both ways; if you are sure that your machine does not have dig installed, you can set it to false to prevent unnecessary checks.

use KnotsPHP\PublicIP\Fetcher\DigFetcher;
 
DigFetcher::$isSupported = true;

If you use the CurlFetcher or FileGetContentsFetcher, you can set the forceHTTP property to true to use HTTP instead of HTTPS. Some whoami services do not support HTTPS anyway as they are meant to be used in scripts like this curl ifconfig.co.

use KnotsPHP\PublicIP\Fetcher\CurlFetcher;
use KnotsPHP\PublicIP\Fetchers\FileGetContentsFetcher;
 
CurlFetcher::$forceHTTP = true;
FileGetContentsFetcher::$forceHTTP = true;

πŸ“– Documentation

dig provider list

IP4or6 IPv4 IPv6 Reliable?
Cloudflare βœ… βœ… βœ… βœ…
Google βœ… βœ…
OpenDNS βœ… βœ… βœ… ⚠️ says they have blocked France & Portugal but seems to work in France in my testings
Akamai ⚠️ ⚠️ ⚠️ ⚠️ last digits of the IP can be wrong

HTTP whoami provider list

IPv4 IPv6 IP4or6 Note
ifconfig.co βœ… βœ… βœ… Fast
ipify.org βœ… βœ… βœ… Open-source
ifconfig.me βœ… βœ… βœ…
icanhazip.com βœ… βœ… βœ…
cloudflare.com βœ… βœ… βœ… Use more data
ipinfo.io βœ… ⚠️ only IPv4
amazonaws.com βœ… ⚠️ only IPv4

πŸ“‹ TODO

Contributions are welcome!

  • use Symfony ExecutableFinder to find dig
  • use Symfony Process to run dig
  • PSR-18 HTTP fetcher with a way to choose psr compatible client so other tools can monitor outgoing requests

🀝 Contributing

Clone the project and run composer update to install the dependencies.

Before pushing your changes, run composer qa.

This will run pint (code style), phpstan (static analysis), and pest (tests).

πŸ“¦ Alternatives

If you are not pleased with this library, check out the following alternatives:

You can also contribute to this library by opening an issue or a pull request.

πŸ‘₯ Credits

PublicIP was created by Eser DENIZ.

πŸ“ License

PublicIP is licensed under the MIT License. See LICENSE for more information.

knotsphp photo

A set of PHP packages designed to work on any operating system. Goes well with PHP TUI and NativePHP apps.

Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.


Knotsphp Publicip Related Articles

Get a Server's Public IP Address With PHP image

Get a Server's Public IP Address With PHP

Read article
Statamic logo

Statamic

The drop-in ready Laravel CMS you’re been waiting for. Go full-stack or headless, flat file or database – it’s up to you.

Statamic
Celebian logo

Celebian

Celebian is a social media marketing agency specializing in helping their clients go viral on TikTok. Whether you're looking to reach a bigger audience or gain more Tiktok followers, likes, and views, they've got you covered.

Celebian
Curotec logo

Curotec

World class Laravel experts with GenAI dev skills. LATAM-based, embedded engineers that ship fast, communicate clearly, and elevate your product. No bloat, no BS.

Curotec
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS Starter Kit

SaaSykit is a Multi-tenant Laravel SaaS Starter Kit that comes with all features required to run a modern SaaS. Payments, Beautiful Checkout, Admin Panel, User dashboard, Auth, Ready Components, Stats, Blog, Docs and more.

SaaSykit: Laravel SaaS Starter Kit
Laravel Cloud logo

Laravel Cloud

Easily create and manage your servers and deploy your Laravel applications in seconds.

Laravel Cloud
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum