The Query
The library provides a Query
class to ease query string creation and manipulation. This URI component object exposes the package common API, but also provide specific methods to work with the URI query component.
Basic usage
<?php
public Query::__construct(?string $content = null, string $separator = '&'): void
public Query::append(string $query): self
public Query::getSeparator(string $separator): self
public Query::ksort(mixed $sort): self
public Query::merge(string $query): self
public Query::withSeparator(string $separator): self
Query::__construct
<?php
public Query::__construct(?string $content = null, string $separator = '&'): void
The League\Uri\Components\Exception
extends PHP’s SPL InvalidArgumentException
.
Query::getSeparator and Query::withSeparator
<?php
public Query::getSeparator(string $separator): self
public Query::withSeparator(void): string
Query::getSeparator
returns the current separator attached to the Query
object while
Query::withSeparator returns a new
Query` object with an alternate string separator.
Query::withSeparator
expects a single argument which is a string separator. If the separator is equal to =
an exception will be thrown.
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&baz=toto');
$newQuery = $query->withSeparator('|');
$newQuery->__toString(); //return foo=bar|baz=toto
Query::merge
Query::merge
returns a new Query
object with its data merged.
<?php
public Query::merge(string $query): Query
This method expects a single argument which is a string
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&baz=toto');
$newQuery = $query->merge('foo=jane&r=stone');
$newQuery->__toString(); //return foo=jane&baz=toto&r=stone
// the 'foo' parameter was updated
// the 'r' parameter was added
<?php
use League\Uri\Components\Query;
$query = Query::createFromPairs(['foo' => 'bar', 'baz' => 'toto']);
$newQuery = $query->merge('baz=&r');
$newQuery->__toString(); //return foo=bar&baz=&r
// the 'r' parameter was added without any value
// the 'baz' parameter was updated to an empty string and its = sign remains
Query::append
Query::append
returns a new Query
object with its data append to it.
<?php
public Query::append(string $query): Query
This method expects a single argument which is a string
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&john=doe');
$newQuery = $query->append('foo=baz');
$newQuery->__toString(); //return foo=jane&foo=baz&john=doe
// a new foo parameter is added
Query::ksort
Query::ksort
returns a Query
object with its pairs sorted according to its keys or a user defined function.
The single argument sort
can be:
One of PHP’s sorting constant used by the sort function. In this case the query parameters are sorted from low to high like PHP’s ksort function
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&baz=toto');
$newQuery = $query->ksort(SORT_STRING);
$newQuery->__toString(); //return baz=toto&foo=bar
A user-defined comparison function which must return an integer less than, equal to, or greater than zero if the first argument is considered to be respectively less than, equal to, or greater than the second, like PHP’s uksort function
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&baz=toto');
$newQuery = $query->ksort('strcmp');
$newQuery->__toString(); //return baz=toto&foo=bar
Query as a PHP data transport layer
<?php
public static Query::createFromParams(array $params, string $separator = '&'): self
public Query::getParams(): array
public Query::getParam(string $name, $default = null): mixed
public Query::withoutNumericIndices(): self
public Query::withoutParams(string[] $offsets): self
Query::createFromParams
This named constructor takes any iterable construct and tries to recreate a Query
object using internally http_build_query
. This method takes 2 arguments:
$params
: a iterable containing properties to transform into a query string;$separator
: the separator to be used when creating the query string representation;
<?php
use League\Uri\Components\Query;
$query = Query::createFromParams(['foo' => 'bar', 'filter' => ['status' => 'on', 'order' => 'desc']], '&');
echo $query->getContent(Query::NO_ENCODING); //return 'foo=bar&filter[status]=on&filter[order]=desc';
Query::getParams
If you already have an instantiated Query
object you can return all the query string deserialized arguments using the Query::getParams
method:
<?php
use League\Uri\Components\Query;
$query_string = 'foo.bar=bar&foo_bar=baz';
parse_str($query_string, $out);
var_export($out);
// $out = ["foo_bar" => 'baz'];
$arr = (new Query($query_string))->getParams();
// $arr = ['foo.bar' => 'bar', 'foo_bar' => baz']];
Query::getParam
If you are only interested in a given argument you can access it directly using the Query::getParam
method as show below:
<?php
use League\Uri\Components\Query;
$query = new Query('foo[]=bar&foo[]=y+olo&z=');
$query->getParam('foo'); //return ['bar', 'y+olo']
$query->getParam('gweta', 'now'); //return 'now'
The method returns the value of a specific argument. If the argument does not exist it will return the value specified by the second argument which defaults to null
.
Query::withoutParams
If you want to remove PHP’s variable from the query string you can use the Query::withoutParams
method as shown below
<?php
use League\Uri\Components\Query;
$query = new Query('foo[]=bar&foo[]=y+olo&z=');
$new_query = $query->withoutParams(['foo']);
$new_query->getParam('foo'); //return null
echo $new_query->getContent(Query::NO_ENCODING); //return 'z='
Query::withoutNumericIndices
If your query string is created with http_build_query
or the Query::createFromParams
named constructor chances are that numeric indices have been added by the method. The Query::withoutNumericIndices
removes any numeric index found in the query string as shown below:
<?php
use League\Uri\Components\Query;
$query = Query::createFromParms('foo[]=bar&foo[]=baz');
echo $query->getContent(Query::NO_ENCODING); //return 'foo[0]=bar&foo[1]=baz'
$new_query = $query->withoutNumericIndices();
echo $new_query->getContent(Query::NO_ENCODING); //return 'foo[]=bar&foo[]=baz'
//of note both objects returns the same PHP's variables but differs regarding the pairs
$query->getParams(); //return ['foo' => ['bar', 'baz']]
$new_query->getParams(); //return ['foo' => ['bar', 'baz']]
Query as a collection of key/value pairs
<?php
public static Query::createFromPairs(iterable $pairs[, string $separator = '&']): self
public Query::getPairs(): array
public Query::getPair(string $offset, $default = null): mixed
public Query::hasPair(string $offset): bool
public Query::keys([mixed $value = null]): array
public Query::withoutEmptyPairs(): self
public Query::withoutPairs(array $offsets): self
This class mainly represents the query string as a collection of key/value pairs.
Query::createFromPairs
Returns a new Query
object from an array
or a Traversable
object.
-
$pairs
: The submitted data must be anarray
or aTraversable
key/value structure similar to the result of Query::parse. -
$separator
: The query string separator used for string representation. By default equals to&
;
Examples
<?php
use League\Uri\Components\Query;
$query = Query::createFromPairs([
'foo' => 'bar',
'p' => 'yolo',
'z' => ''
]);
echo $query; //display 'foo=bar&p=yolo&z='
$query = Query::createFromPairs([
'foo' => 'bar',
'p' => null,
'z' => ''
]);
echo $query; //display 'foo=bar&p&z='
Countable and IteratorAggregate
The class implements PHP’s Countable
and IteratorAggregate
interfaces. This means that you can count the number of pairs and use the foreach
construct to iterate over them.
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&p=y+olo&z=');
count($query); //return 4
foreach ($query as $key => $value) {
//do something meaningful here
}
Query::getPairs
The Query::getPairs
method returns the object’s array representation.
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&p=y+olo&z=');
$query->getPairs();
// returns [
// 'foo' => 'bar',
// 'p' => 'y olo',
// 'z' => '',
// ]
Query::getPair
If you are only interested in a given pair you can access it directly using the Query::getPair
method as show below:
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&p=y+olo&z=');
$query->getPair('foo'); //return 'bar'
$query->getPair('gweta'); //return null
$query->getPair('gweta', 'now'); //return 'now'
The method returns the value of a specific pair key. If the key does not exist it will return the value specified by the second argument which defaults to null
.
Query::hasPair
Because a pair value can be null
the Query::hasPair
method is used to remove the possible Query::getPair
result ambiguity.
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&p&z=');
$query->getPair('foo'); //return 'bar'
$query->getPair('p'); //return null
$query->getPair('gweta'); //return null
$query->hasPair('gweta'); //return false
$query->hasPair('p'); //return true
Query::keys
If you are interested in getting the pairs keys you can do so using the Query::keys
method.
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&p=y+olo&z=');
$query->keys(); //return ['foo', 'p', 'z'];
$query->keys('bar'); //return ['foo'];
$query->keys('gweta'); //return [];
By default, the method returns all the keys, but if you supply a value, only the keys whose value equals the value are returned.
Query::withoutPairs
Query::withoutPairs
returns a new Query
object with deleted pairs according to their keys.
This method expects an array containing a list of keys to remove as its single argument.
<?php
use League\Uri\Components\Query;
$query = new Query('foo=bar&p=y+olo&z=');
$newQuery = $query->withoutPairs(['foo', 'p']);
echo $newQuery; //displays 'z='
Query::withoutEmptyPairs
Query::withoutEmptyPairs
returns a new Query
object with deleted empty pairs. A pair is considered empty if its key equals the empty string and its value is null
.
<?php
use League\Uri\Components\Query;
$query = new Query('&&=toto&&&&=&');
$newQuery = $query->withoutEmptyPairs();
echo $query; //displays '&&=toto&&&&=&'
echo $newQuery; //displays '=toto&='