slexx/headers

Http headers parser

1.0.0 2017-07-19 20:16 UTC

This package is auto-updated.

Last update: 2024-10-08 07:22:08 UTC


README

Latest Stable Version Total Downloads Latest Unstable Version License

Установка

$ composer require slexx/headers

Базовое использование

Класс разбивает HTTP заголовки на массив и предоставляет удобную обёртку для ними.

$headers = new Slexx\Headers\Headers("Content-Type: image/jpeg\r\nAccept-Charset: utf-8\r\nX-My-Custom-Header: Zeke are cool");

echo $headers->get('Content-Type');
// -> image/jpeg

API

Headers::parse($headers)

Аргументы:

Возвращает: array - Массив заголовков где ключ это имя заголовка.

Пример:

use Slexx\Headers\Headers;

var_dump(Headers::parse("Content-Type: image/jpeg\r\nAccept-Charset: utf-8\r\nX-My-Custom-Header: Zeke are cool"));
var_dump(Headers::parse([
    'Content-Type: image/jpeg',
    'Accept-Charset: utf-8',
    'X-My-Custom-Header: Zeke are cool'
]));

Headers->set($name, $value)

Добавляет заголовок или изменяет существующий.

Аргументы:

Возвращает: void

Headers->remove($name)

Удаляет заголовок

Аргументы:

Возвращает: void

Headers->has($name)

Проверяет существование заголовка

Аргументы:

Возвращает: boolean

Headers->get($name)

Возвращает значение заголовка

Аргументы:

Возвращает: string|null

Headers->__toString()

Преобразует заголовки в строку

Возвращает: string

Headers->toArray()

Возвращает массив заголовков

Возвращает: array

Headers->count()

Подсщитывает колличество заголовков

Возвращает: int

Headers->getIterator()

Позволяет перебирать заголовки в цикле foreach

Возвращает: ArrayIterator

Пример:

$headers = new Headers([
    'Content-Type: image/jpeg',
    'Accept-Charset: utf-8',
    'X-My-Custom-Header: Zeke are cool'
]);
foreach($headers as $name => $value) {
    echo "$name: $value\r\n";
}