Vap*_*p0r 5 ajax jquery header setting
我没有使用设置请求标头的beforeSend方法,而是决定使用jQuery $ .ajax()调用的headers设置选项.当然,我在这里访问了这个页面,http://api.jquery.com/jQuery.ajax/,但文档很少,我找不到任何方法来设置多个标题以及在该页面上执行此操作的格式或其他任何地方.
@tahir:那为什么这不起作用?
<!DOCTYPE html>
<html>
<head>
<title>Multiple DnD Uploader</title>
<link rel="stylesheet" href="style.css" />
<script type = "text/javascript" src = "../music/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$('#drop').change(function(event){
files = event.target.files;
$('#drop').css('display', 'none');
for(var i = 0, len = files.length; i < len; i++) {
alert(files[i].fileName);
$.ajax({
type: "POST",
url: "uploader.php",
contentType: "multipart/form-data",
headers: {
"X-File-Name" : ""+files[i].fileName,
"X-File-Size" : ""+files[i].fileSize
},
data: 'hi',
success: function(data){
$('#info').append('Success: ' + data + '<br />');
},error: function(data){
$('#info').append('Error: ' + data + '<br />');
}
});
}
});
});
</script>
</head>
<body>
<div id="drop">
<h1>Drop files here</h1>
<p>To add them as attachments</p>
<input type="file" multiple="true" id="filesUpload" />
</div>
<div id="info">
</div>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
两个X-File-Name和X-File-Size属性未显示在请求标头中.
解决方案:我觉得非常愚蠢,结果我指向的特定jquery.js文件是1.4.4,所以我升级了,现在它可以工作了!谢谢.
它说:
与请求一起发送的附加标头键/值对的映射。该设置是在调用beforeSend函数之前设置的;因此, headers 设置中的任何值都可以在 beforeSend 函数中被覆盖。
所以你所要做的就是传递一个像这样的对象:
{"header1":"value1","header2":"value2"}
Run Code Online (Sandbox Code Playgroud)
等等。以下是在 post 请求中添加 Accept 标头的一些代码:
$.ajax("relative/url/action.do",{
success: function(){
alert("success");
},
error: function(jqXHR, textStatus, errorThrown){
alert(textStatus + ": " + jqXHR.responseText );
},
headers: {Accept: "application/json"},
type : "POST"
});
Run Code Online (Sandbox Code Playgroud)