芝麻web文件管理V1.00
编辑当前文件:/home2/sdektunc/xmintal-back/vendor/yiisoft/yii2/web/HeaderCollection.php
* @since 2.0 */ class HeaderCollection extends BaseObject implements \IteratorAggregate, \ArrayAccess, \Countable { /** * @var array the headers in this collection (indexed by the normalized header names) */ private $_headers = []; /** * @var array the original names of the headers (indexed by the normalized header names) */ private $_originalHeaderNames = []; /** * Returns an iterator for traversing the headers in the collection. * This method is required by the SPL interface [[\IteratorAggregate]]. * It will be implicitly called when you use `foreach` to traverse the collection. * @return \ArrayIterator an iterator for traversing the headers in the collection. */ #[\ReturnTypeWillChange] public function getIterator() { return new \ArrayIterator($this->_headers); } /** * Returns the number of headers in the collection. * This method is required by the SPL `Countable` interface. * It will be implicitly called when you use `count($collection)`. * @return int the number of headers in the collection. */ #[\ReturnTypeWillChange] public function count() { return $this->getCount(); } /** * Returns the number of headers in the collection. * @return int the number of headers in the collection. */ #[\ReturnTypeWillChange] public function getCount() { return count($this->_headers); } /** * Returns the named header(s). * @param string $name the name of the header to return * @param mixed $default the value to return in case the named header does not exist * @param bool $first whether to only return the first header of the specified name. * If false, all headers of the specified name will be returned. * @return string|array|null the named header(s). If `$first` is true, a string will be returned; * If `$first` is false, an array will be returned. */ public function get($name, $default = null, $first = true) { $normalizedName = strtolower($name); if (isset($this->_headers[$normalizedName])) { return $first ? reset($this->_headers[$normalizedName]) : $this->_headers[$normalizedName]; } return $default; } /** * Adds a new header. * If there is already a header with the same name, it will be replaced. * @param string $name the name of the header * @param string $value the value of the header * @return $this the collection object itself */ public function set($name, $value = '') { $normalizedName = strtolower($name); $this->_headers[$normalizedName] = (array) $value; $this->_originalHeaderNames[$normalizedName] = $name; return $this; } /** * Adds a new header. * If there is already a header with the same name, the new one will * be appended to it instead of replacing it. * @param string $name the name of the header * @param string $value the value of the header * @return $this the collection object itself */ public function add($name, $value) { $normalizedName = strtolower($name); $this->_headers[$normalizedName][] = $value; if (!\array_key_exists($normalizedName, $this->_originalHeaderNames)) { $this->_originalHeaderNames[$normalizedName] = $name; } return $this; } /** * Sets a new header only if it does not exist yet. * If there is already a header with the same name, the new one will be ignored. * @param string $name the name of the header * @param string $value the value of the header * @return $this the collection object itself */ public function setDefault($name, $value) { $normalizedName = strtolower($name); if (empty($this->_headers[$normalizedName])) { $this->_headers[$normalizedName][] = $value; $this->_originalHeaderNames[$normalizedName] = $name; } return $this; } /** * Returns a value indicating whether the named header exists. * @param string $name the name of the header * @return bool whether the named header exists */ public function has($name) { return isset($this->_headers[strtolower($name)]); } /** * Removes a header. * @param string $name the name of the header to be removed. * @return array|null the value of the removed header. Null is returned if the header does not exist. */ public function remove($name) { $normalizedName = strtolower($name); if (isset($this->_headers[$normalizedName])) { $value = $this->_headers[$normalizedName]; unset($this->_headers[$normalizedName], $this->_originalHeaderNames[$normalizedName]); return $value; } return null; } /** * Removes all headers. */ public function removeAll() { $this->_headers = []; $this->_originalHeaderNames = []; } /** * Returns the collection as a PHP array. * @return array the array representation of the collection. * The array keys are header names, and the array values are the corresponding header values. */ public function toArray() { return $this->_headers; } /** * Returns the collection as a PHP array but instead of using normalized header names as keys (like [[toArray()]]) * it uses original header names (case-sensitive). * @return array the array representation of the collection. * @since 2.0.45 */ public function toOriginalArray() { return \array_map(function ($normalizedName) { return $this->_headers[$normalizedName]; }, \array_flip($this->_originalHeaderNames)); } /** * Populates the header collection from an array. * @param array $array the headers to populate from * @since 2.0.3 */ public function fromArray(array $array) { foreach ($array as $name => $value) { $this->set($name, $value); } } /** * Returns whether there is a header with the specified name. * This method is required by the SPL interface [[\ArrayAccess]]. * It is implicitly called when you use something like `isset($collection[$name])`. * @param string $name the header name * @return bool whether the named header exists */ #[\ReturnTypeWillChange] public function offsetExists($name) { return $this->has($name); } /** * Returns the header with the specified name. * This method is required by the SPL interface [[\ArrayAccess]]. * It is implicitly called when you use something like `$header = $collection[$name];`. * This is equivalent to [[get()]]. * @param string $name the header name * @return string|null the header value with the specified name, null if the named header does not exist. */ #[\ReturnTypeWillChange] public function offsetGet($name) { return $this->get($name); } /** * Adds the header to the collection. * This method is required by the SPL interface [[\ArrayAccess]]. * It is implicitly called when you use something like `$collection[$name] = $header;`. * This is equivalent to [[add()]]. * @param string $name the header name * @param string $value the header value to be added */ #[\ReturnTypeWillChange] public function offsetSet($name, $value) { $this->set($name, $value); } /** * Removes the named header. * This method is required by the SPL interface [[\ArrayAccess]]. * It is implicitly called when you use something like `unset($collection[$name])`. * This is equivalent to [[remove()]]. * @param string $name the header name */ #[\ReturnTypeWillChange] public function offsetUnset($name) { $this->remove($name); } }