如何使用 Ajax Post .json 文件到 ArangoDB
How to Post a .json file to ArangoDB using Ajax
我正在尝试 post 一个 .json 文件作为单个文档到 ArangoDB 集合,从 javascript/ajax.
我可以 post(对 ArangoDB)使用 curl 的 .json 文件,这样就可以了
我可以使用 AJAX post(对 ArangoDB)简单的 {key: value} 对,这样就可以了,但是将两者结合起来似乎太过分了。我花了几个晚上试图做到这一点,所以任何帮助都将不胜感激。提前致谢。
我的 javascript 代码如下所示
var database_URL = prompt("Please enter your URL", "http://xxx..xxx.xxxx.:8529/_db/collection_name/_api/document?collection=PA_Users&createCollection=false");
var fd = new FormData();
var selectedFile = document.getElementById('files').files[0];
console.log(selectedFile.name);// this works
fd.append(selectedFile.name,selectedFile);
var settings = {
url : database_URL,
type : "POST",
headers: {
'Authorization': "Basic " + btoa(username1 + ":" + passwrd1)
},
data: fd,
processData: false,
success: function(data) {
// display feedback to user
alert("booyah");
},
error: function(data) {
// display feedback to user
alert("boo hoo");
}
};
$.ajax(settings);
我认为你应该使用 /_api/import 而不是 /_api/document:
HTTP Interface for Bulk Imports
这是一个小的工作示例(未经授权):
$.ajax({
type: "POST",
url:
'/_api/import?type=auto&collection=' +
encodeURIComponent(yourCollectionID) +
'&createCollection=false',
data: file,
processData: false,
contentType: 'json',
dataType: 'json',
complete: function(xhr) {
if (xhr.readyState === 4 && xhr.status === 201) {
callback(false);
} else {
try {
var data = JSON.parse(xhr.responseText);
if (data.errors > 0) {
// error
}
else {
// success
}
}
catch (err) {
console.log(err);
}
}
}
});
}
api 支持几种输入格式:
1.) 单个文档
{name: "Jonny"}
2.) 多个文档(每行一个文档)
{name: "Jonny"}
{name: "Adam"}
{name: "Peter"}
3.) JSON 数组
中的多个文档
[{name: "Jonny"}, {name: "Adam"}, {name: "Peter"}]
我正在尝试 post 一个 .json 文件作为单个文档到 ArangoDB 集合,从 javascript/ajax.
我可以 post(对 ArangoDB)使用 curl 的 .json 文件,这样就可以了 我可以使用 AJAX post(对 ArangoDB)简单的 {key: value} 对,这样就可以了,但是将两者结合起来似乎太过分了。我花了几个晚上试图做到这一点,所以任何帮助都将不胜感激。提前致谢。
我的 javascript 代码如下所示
var database_URL = prompt("Please enter your URL", "http://xxx..xxx.xxxx.:8529/_db/collection_name/_api/document?collection=PA_Users&createCollection=false");
var fd = new FormData();
var selectedFile = document.getElementById('files').files[0];
console.log(selectedFile.name);// this works
fd.append(selectedFile.name,selectedFile);
var settings = {
url : database_URL,
type : "POST",
headers: {
'Authorization': "Basic " + btoa(username1 + ":" + passwrd1)
},
data: fd,
processData: false,
success: function(data) {
// display feedback to user
alert("booyah");
},
error: function(data) {
// display feedback to user
alert("boo hoo");
}
};
$.ajax(settings);
我认为你应该使用 /_api/import 而不是 /_api/document:
HTTP Interface for Bulk Imports
这是一个小的工作示例(未经授权):
$.ajax({
type: "POST",
url:
'/_api/import?type=auto&collection=' +
encodeURIComponent(yourCollectionID) +
'&createCollection=false',
data: file,
processData: false,
contentType: 'json',
dataType: 'json',
complete: function(xhr) {
if (xhr.readyState === 4 && xhr.status === 201) {
callback(false);
} else {
try {
var data = JSON.parse(xhr.responseText);
if (data.errors > 0) {
// error
}
else {
// success
}
}
catch (err) {
console.log(err);
}
}
}
});
}
api 支持几种输入格式:
1.) 单个文档
{name: "Jonny"}
2.) 多个文档(每行一个文档)
{name: "Jonny"}
{name: "Adam"}
{name: "Peter"}
3.) JSON 数组
中的多个文档[{name: "Jonny"}, {name: "Adam"}, {name: "Peter"}]