我确实收到了响应数据,但我无法获取自定义HTTP标头数据。
是的,这是一个跨域请求。我正在用Javascript做一个Ajax请求。我用XMLHttpRequest和jQuery $ .ajax尝试过这个。我已完成服务器设置,发送数据时设置了这些设置:
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: POST, GET
我做获取我想要的响应数据。但我无法获得完整的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的开发者工具,我会发现这些工具确实会返回完整的HTTP标头信息,包括Content-Length
,Content-Encoding
,Vary
,{{1} },X-Powered-By
,Set-Cookie
,当然还有Server
。
答案 0 :(得分:43)
我想感谢jbl指出我正确的SO问题。我现在明白了......
所以,好的......答案。如果你想设置自己的HTTP头信息,然后使用跨域Ajax或类似的东西来获取它,那么在发送响应文本之前,你应该在服务器端设置一些额外的HTTP头。
header('Access-Control-Allow-Origin: *');
header("Access-Control-Allow-Methods: POST, GET");
header('Custom-Header: Own-Data');
header('Access-Control-Expose-Headers: Custom-Header');
上面的例子使用PHP。但是使用你自己的语言,你用它来设置它们。
当我问这个问题时,我除了Access-Control-Expose-Headers
之外还有其他所有问题。放入后,我的Javascript Ajax可以读取HTTP Header Custom-Header的内容。