A PHP library for URL manipulation, compatible with PSR-7 UriInterface

2.0.1 2026-04-15 19:57 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT ad13fabade7872e35fa8256f9721cbc42c5c9d86


README

πŸ‘ Tests
πŸ‘ Latest Stable Version
πŸ‘ PHP
πŸ‘ Total Downloads
πŸ‘ License

A PHP library for URL manipulation, implementing PSR-7 UriInterface.

Requirements

  • PHP 8.2+

Installation

composer require codeinc/url

Usage

Parsing a URL

use CodeInc\Url\Url;

$url = Url::fromString('https://www.example.com/search?q=php&page=1#results');

$url->getScheme(); // 'https'
$url->getHost(); // 'www.example.com'
$url->getPath(); // '/search'
$url->getQuery(); // 'q=php&page=1'
$url->getQueryAsArray(); // ['q' => 'php', 'page' => '1']
$url->getFragment(); // 'results'

Building a URL

$url = (new Url())
 ->withScheme('https')
 ->withHost('api.example.com')
 ->withPath('/v2/users')
 ->withQueryParams(['page' => '1', 'limit' => '50']);

echo $url; // https://api.example.com/v2/users?page=1&limit=50

Modifying a URL

All with* methods return a new immutable instance:

$url = Url::fromString('https://example.com/path?a=1&b=2#frag');

$modified = $url
 ->withScheme('http')
 ->withQueryParams(['c' => '3'])
 ->withoutFragment();

echo $modified; // http://example.com/path?a=1&b=2&c=3
echo $url; // https://example.com/path?a=1&b=2#frag (unchanged)

Removing components

$url->withoutScheme();
$url->withoutHost();
$url->withoutPort();
$url->withoutUserInfo();
$url->withoutPath();
$url->withoutFragment();
$url->withoutQuery(); // removes entire query string
$url->withoutQuery(['a', 'b']); // removes specific parameters

PSR-7 interop

// From a PSR-7 UriInterface
$url = Url::fromPsr7Uri($psr7Uri);

// From a PSR-7 ServerRequestInterface
$url = Url::fromPsr7Request($serverRequest);

// Use anywhere a UriInterface is expected
function processUri(UriInterface $uri): void { /* ... */ }
processUri($url);

Getting the current URL

$url = Url::fromGlobals();

Tests

composer install
vendor/bin/phpunit

License

This library is published under the MIT license (see LICENSE file).