Я получаю данные ответа, но я не могу получить данные пользовательского HTTP-заголовка.
Да, это междоменный запрос. Я делаю запрос Ajax с Javascript. Я пробовал это с помощью XMLHttpRequest, а также jQuery $.ajax. Я выполнил настройки своего сервера, у меня есть эти настройки при отправке данных:
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: POST, GET
I сделать получить данные ответа, которые я хочу. Но я не могу получить полный ответ HTTP-заголовка.
С PHP я установил следующее перед отправкой текстового ответа. Поэтому я предполагаю, что я должен получить его с помощью getAllResponseHeaders().
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('My-Own-Test: nodatahere');
Но вот что я получил.
Content-Type: text/plain; charset=x-user-defined
Cache-Control: must-revalidate, post-check=0, pre-check=0
Expires: 0
Отсутствует My-Own-Test
. Только для справки, здесь мой Javascript:
var formData = new FormData();
formData.append('username', 'my_username');
formData.append('book_id', 'test password');
var xhr = new XMLHttpRequest();
xhr.open('POST', 'https://mydomain.com/proc.php', true);
xhr.overrideMimeType("text/plain; charset=x-user-defined");
xhr.onload = function(e) {
console.log(this.getAllResponseHeaders());
};
xhr.send(formData);
Я даже попробовал его с jQuery... тот же результат.
var data_to_send = {
username: 'my_username',
password: 'test_password'
};
var ajaxObj;
ajaxObj = $.ajax({
url: "https://mydomain.com/proc.php",
data: data_to_send,
type: "POST",
beforeSend: function ( xhr ) {
xhr.overrideMimeType("text/plain; charset=x-user-defined");
}
})
.done(function ( data ) {
console.log( ajaxObj.getAllResponseHeaders() );
});
Еще... не повезло.
Но если я пройду через Firebug или Chrome Developer Tool, я вижу, что эти инструменты возвращают полную информацию заголовка HTTP, включая Content-Length
, Content-Encoding
, Vary
, X-Powered-By
, Set-Cookie
, Server
, и, конечно, My-Own-Test
.