home
/
aioutajg
/
test.imgccr.com
/
vendor
/
guzzlehttp
/
psr7
/
src
/
Go to Home Directory
+
Upload
Create File
root@0UT1S:~$
Execute
By Order of Mr.0UT1S
[DIR] ..
N/A
[DIR] Exception
N/A
AppendStream.php
5.81 KB
Rename
Delete
BufferStream.php
3.14 KB
Rename
Delete
CachingStream.php
4.49 KB
Rename
Delete
DroppingStream.php
1.17 KB
Rename
Delete
FnStream.php
4.21 KB
Rename
Delete
Header.php
3.85 KB
Rename
Delete
HttpFactory.php
3.00 KB
Rename
Delete
InflateStream.php
1.38 KB
Rename
Delete
LazyOpenStream.php
1.06 KB
Rename
Delete
LimitStream.php
4.20 KB
Rename
Delete
Message.php
8.14 KB
Rename
Delete
MessageTrait.php
7.56 KB
Rename
Delete
MimeType.php
53.75 KB
Rename
Delete
MultipartStream.php
5.06 KB
Rename
Delete
NoSeekStream.php
524 bytes
Rename
Delete
PumpStream.php
4.49 KB
Rename
Delete
Query.php
3.95 KB
Rename
Delete
Request.php
3.82 KB
Rename
Delete
Response.php
4.79 KB
Rename
Delete
Rfc7230.php
661 bytes
Rename
Delete
ServerRequest.php
9.33 KB
Rename
Delete
Stream.php
7.21 KB
Rename
Delete
StreamDecoratorTrait.php
3.24 KB
Rename
Delete
StreamWrapper.php
4.53 KB
Rename
Delete
UploadedFile.php
4.75 KB
Rename
Delete
Uri.php
21.44 KB
Rename
Delete
UriComparator.php
1.12 KB
Rename
Delete
UriNormalizer.php
8.26 KB
Rename
Delete
UriResolver.php
8.38 KB
Rename
Delete
Utils.php
15.57 KB
Rename
Delete
<?php declare(strict_types=1); namespace GuzzleHttp\Psr7; final class Query { /** * Parse a query string into an associative array. * * If multiple values are found for the same key, the value of that key * value pair will become an array. This function does not parse nested * PHP style arrays into an associative array (e.g., `foo[a]=1&foo[b]=2` * will be parsed into `['foo[a]' => '1', 'foo[b]' => '2'])`. * * @param string $str Query string to parse * @param int|bool $urlEncoding How the query string is encoded */ public static function parse(string $str, $urlEncoding = true): array { $result = []; if ($str === '') { return $result; } if ($urlEncoding === true) { $decoder = function ($value) { return rawurldecode(str_replace('+', ' ', (string) $value)); }; } elseif ($urlEncoding === PHP_QUERY_RFC3986) { $decoder = 'rawurldecode'; } elseif ($urlEncoding === PHP_QUERY_RFC1738) { $decoder = 'urldecode'; } else { $decoder = function ($str) { return $str; }; } foreach (explode('&', $str) as $kvp) { $parts = explode('=', $kvp, 2); $key = $decoder($parts[0]); $value = isset($parts[1]) ? $decoder($parts[1]) : null; if (!array_key_exists($key, $result)) { $result[$key] = $value; } else { if (!is_array($result[$key])) { $result[$key] = [$result[$key]]; } $result[$key][] = $value; } } return $result; } /** * Build a query string from an array of key value pairs. * * This function can use the return value of `parse()` to build a query * string. This function does not modify the provided keys when an array is * encountered (like `http_build_query()` would). * * @param array $params Query string parameters. * @param int|false $encoding Set to false to not encode, * PHP_QUERY_RFC3986 to encode using * RFC3986, or PHP_QUERY_RFC1738 to * encode using RFC1738. * @param bool $treatBoolsAsInts Set to true to encode as 0/1, and * false as false/true. */ public static function build(array $params, $encoding = PHP_QUERY_RFC3986, bool $treatBoolsAsInts = true): string { if (!$params) { return ''; } if ($encoding === false) { $encoder = function (string $str): string { return $str; }; } elseif ($encoding === PHP_QUERY_RFC3986) { $encoder = 'rawurlencode'; } elseif ($encoding === PHP_QUERY_RFC1738) { $encoder = 'urlencode'; } else { throw new \InvalidArgumentException('Invalid type'); } $castBool = $treatBoolsAsInts ? static function ($v) { return (int) $v; } : static function ($v) { return $v ? 'true' : 'false'; }; $qs = ''; foreach ($params as $k => $v) { $k = $encoder((string) $k); if (!is_array($v)) { $qs .= $k; $v = is_bool($v) ? $castBool($v) : $v; if ($v !== null) { $qs .= '='.$encoder((string) $v); } $qs .= '&'; } else { foreach ($v as $vv) { $qs .= $k; $vv = is_bool($vv) ? $castBool($vv) : $vv; if ($vv !== null) { $qs .= '='.$encoder((string) $vv); } $qs .= '&'; } } } return $qs ? (string) substr($qs, 0, -1) : ''; } }
Save