我没有使用设置请求标头的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>
两个X-File-Name和X-File-Size属性未显示在请求标头中。
解决方案:我觉得非常愚蠢,原来我指向的特定jquery.js文件是1.4.4,所以我升级了,现在它可以工作了!感谢。
答案 0 :(得分:4)
它说:
要与请求一起发送的其他标头键/值对的映射。在调用beforeSend函数之前设置此设置;因此,可以从beforeSend函数中覆盖标题设置中的任何值。
所以你要做的就是传递一个像:
这样的对象{"header1":"value1","header2":"value2"}
等等。以下是一些在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"
});