我在使用ajax post发送base64图像数据时遇到问题 我认为我对Content-Type有错误的值但是已经尝试 application / json , text / json 和 image / jpeg 而没有任何成功< / p>
的Javascript
function sendFormData(fD)
{
var urls = fD.get('urls');
console.log('urls', urls);
var xhr = new XMLHttpRequest();
xhr.open('POST', '/editsongs.update_artwork');
alert(urls);
xhr.setRequestHeader("Content-type", "image/jpeg");
xhr.send(urls);
}
浏览器控制台显示
["…
Java服务器代码
public String updateArtwork(Request request, Response response)
{
System.out.println("Received artwork");
for(String s:request.queryParams())
{
System.out.println("---"+s);
}
System.out.println("ReadParms");
return "";
}
只是输出
Received artwork
ReadParms
已更新为“以表格形式发送”
// Once we got everything, time to retrieve our objects
function sendData()
{
var fD = new FormData();
// send Files data directly
var files = imgList.filter(
function isFile(obj)
{
return obj.type === 'file';
}
);
files.forEach(
function appendToFD(obj)
{
fD.append('files[]', obj.file);
}
);
// for elems, we will need to grab the data from the server
var elems = imgList.filter(
function isElem(obj)
{
return obj.type === "element";
}
);
var urls = elems.map(
function grabURL(obj)
{
return obj.element.src;
}
);
if (urls.length)
fD.append('urls', JSON.stringify(urls));
sendFormData(fD);
};
function sendFormData(fD)
{
// but here we will just log the formData's content
var files = fD.getAll('files[]');
console.log('files: ', files);
var urls = fD.get('urls');
console.log('urls', urls);
var xhr = new XMLHttpRequest();
xhr.open('POST', '/editsongs.update_artwork');
xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhr.send(fD);
}
然后在服务器上我有
public String updateArtwork(Request request, Response response)
{
System.out.println("Received artwork");
for(String s:request.queryParams())
{
System.out.println("***"+s);
System.out.println(request.queryParams(s));
}
System.out.println("ReadParms");
return "";
}
及其输出
Received artwork
***-----------------------------330219842643
Content-Disposition: form-data; name
"urls"
["...."]
-----------------------------330219842643--
ReadParms
所以我现在正在获取数据,但我不明白如何理解如何解析Java中的Content-Disposition部分。
这段代码最初并非由我编写,因为您可以看到构建 FormData 它并非来自实际的表单。我的第一次尝试是尝试从 FormData 中提取并以不同的方式发送,另一种方法是首先不存储在 FormData 中但不知道如何执行此操作
更新2 尝试只发送第一个网址而不是formdata或网址的arrya,因为实际上只有一个url.But它只是不起作用,没有收到服务器?
function sendFormData(urls)
{
console.log('urls', urls[0]);
var xhr = new XMLHttpRequest();
xhr.open('POST', '/editsongs.update_artwork');
xhr.setRequestHeader("Content-type", "text/json");
alert(JSON.stringify(urls[0]));
xhr.send(JSON.stringify(urls[0]));
}
答案 0 :(得分:2)
您正在尝试使用queryParams()
查看正文中的数据,这将为您提供位于网址中的查询参数。
使用body()
从请求正文加载数据。