PHP 7.0.0 RC 8 Released


(PECL pecl_http >= 0.19.0)

http_negotiate_content_typeNegociar el tipo de contenido preferido por los clientes


string http_negotiate_content_type ( array $supported [, array &$result ] )

Esta función se encarga de negociar el tipo de contenido preferido por los clientes basado en su cabecera de HTTP Accept. Se reconoce el calificador y los tipos de contenido sin calificador son valorados como los más altos.



Arreglo que contiene como valores los tipos de contenidos soportados


Serán llenados con un arreglo que contiene los resultados de la negociación

Valores devueltos

Devuelve el tipo de contenido negociado o el que está por predeterminado (por ejemplo, la primer entrada del arreglo) si ninguno coincide.


Ejemplo #1 Utilizando http_negotiate_content_type()

= array('application/xhtml+xml''text/html');

add a note add a note

User Contributed Notes 3 notes

Vasil Rangelov
8 years ago
Newer versions of this extension fix the bug from the previous note.

Still, if you want to ensure there's no match, you can use the array, as the array will remain empty.

I used this fact in the following technique to ensure good content negotiation between application/xhtml+xml and text/html, since IE sends only "*/*" and thus receives application/xhtml+xml if you use the current sample from the documentation.

= http_negotiate_content_type(array('application/xhtml+xml', 'text/html'),
$contentType = (empty($contentTypes) ? 'text/html' : $bestContentType);

Note that at the time of writing, Opera accepts text/html with this approach, because it places application/xhtml+xml with a lower qualifier.
Pieter van Beek
8 years ago
The documentation says:

Returns the negotiated content type or the default content type (i.e. first array entry) if none match.

It would seem that in fact, this method returns the empty string or NULL if none match.
Richard Smith
3 months ago
This function hasn't existed for years.  So unless you have an ancient build of pecl_http, you'll need to work out how to use the wholly undocumented HTTP::Header class.
To Top