NodeJS请求主体返回空{}

时间:2018-12-15 05:07:34

标签: javascript node.js ajax

我有这个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)的位置上将精确打印我要保存的内容。我不知道如何发送空的邮件,因为我是在发送邮件之前立即进行打印的。

知道我在做什么错吗?

1 个答案:

答案 0 :(得分:0)

如果您想将文件上传到后端,则应尝试multer。真的很好,如果您需要,我可以发布示例