发送此 AJAX Post 数据的正确内容类型
Correct content-type for sending this AJAX Post data
我在使用 ajax post 发送 base64 图像数据时遇到问题
我认为我的 Content-Type 值有误,但已尝试 application/json、text/json 和 image/jpeg 没有任何成功
Java脚本
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
尝试只发送第一个 url 而不是 formdata 或 url 的 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]));
}
您正在尝试使用 queryParams()
查看正文中的数据,这将为您提供位于 url.
中的查询参数
使用body()
从请求正文加载数据。
我在使用 ajax post 发送 base64 图像数据时遇到问题 我认为我的 Content-Type 值有误,但已尝试 application/json、text/json 和 image/jpeg 没有任何成功
Java脚本
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 尝试只发送第一个 url 而不是 formdata 或 url 的 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]));
}
您正在尝试使用 queryParams()
查看正文中的数据,这将为您提供位于 url.
使用body()
从请求正文加载数据。