我有这个javascript函数,应该将.json文件上传到服务器。
function project_save_confirmed(input) {
if ( input.project_name.value !== _onco_settings.project.name ) {
project_set_name(input.project_name.value);
}
// onco project
var _onco_project = { '_onco_settings': _onco_settings,
'_onco_img_metadata': _onco_img_metadata,
'_onco_attributes': _onco_attributes };
var filename = input.project_name.value + '.json';
var json = JSON.stringify(_onco_project);
var data_blob = new Blob( [JSON.stringify(_onco_project)],
{type: 'text/json;charset=utf-8'});
//save_data_to_local_file(data_blob, filename);
upload_json_to_server(json, filename);
user_input_default_cancel_handler();
}
async function upload_json_to_server(data_blob, filename) {
console.log(data_blob);
$.ajax({
type: 'POST',
url: 'http://localhost:3000/upload',
body: data_blob,
contentType: 'text/json'
}).done(function (data) {
console.log(data);
});
}
在我的服务器上,我具有与文件上传相对应的路由
const express = require('express');
const fileUpload = require('express-fileupload');
const app = express();
const fs = require('fs');
const bodyParser = require("body-parser");
app.use(function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
next();
});
app.use(bodyParser.json({
extended: true
}));
app.post('/upload', function(req, res) {
console.log(req.body);
fs.writeFileSync('./data/oncofinder-' + Date.now() +'.json', req); //default: 'utf8'
});
app.listen(3000,function(){
console.log("Working on port 3000");
});
但是在我的console.log(req.body)
上,我唯一得到的是{}
。
编辑:
我将JSON作为纯文本传递。在console.log(data_blob)
的位置上将精确打印我要保存的内容。我不知道如何发送空的邮件,因为我是在发送邮件之前立即进行打印的。
知道我在做什么错吗?
答案 0 :(得分:0)
如果您想将文件上传到后端,则应尝试multer。真的很好,如果您需要,我可以发布示例