javascript - Summernote 图像 + Node.js (Express.js)

标签 javascript jquery node.js express summernote

关于如何在 PHP 端处理 Summernote file-upload 的解决方案有太多,但我找不到一个合适的解决方案来展示如何在 Node.js 中处理它。

我的 JavaScript

$(document).ready(function() {
    // $('#summernote').summernote();

    $('#summernote').summernote({
        height: 590,   
        focus: true,
        callbacks: {                                        
            onImageUpload : function(file, editor, welEditable) {
                saveFile(file[0], editor, welEditable);
            }
        }                                
    });

    function saveFile(file, editor, welEditable){
        console.log(file)
        data = new FormData();
        data.append("file", file);
        $.ajax({
            data: data,
            type: "POST",
            url: "/save/wiki",
            cache: false,
            contentType: false,
            processData: false,
            success: function(url) {
                console.log(url)
                editor.insertImage(welEditable, url);
            }
        });
    }
});

app.js

var express     = require('express');
var bodyParser  = require('body-parser');
var multer      = require('multer');
var path        = require('path');
var app         = express();


var jsonPrsr = bodyParser.json();                                        
var urlencodedPrsr = bodyParser.urlencoded({ extended: false });         
var routes = require('./routes')(app, jsonPrsr, urlencodedPrsr, multer); 
var port = process.env.PORT || 1337;                                     


app.listen(port, function(err){
    if(err){
        console.log("Server failed to start on port: "+port+". Description: ");
        console.log(err);
    }else console.log(port+'is ON')
});

routes.js

module.exports = function(app, jsonParser, urlencodedParser, multer) {
    app.post('/save/wiki', urlencodedParser, function(req, res){
        if( typeof req.body != 'undefined' )
            console.log(req.body); // THIS RETURNS {} ie. empty
        var file_name = req.body.file;
        var upload, 
            upload_destination = './public';
            storage = multer.diskStorage({                                  
                 destination: function (req, file, callback) {
                     callback(null, upload_destination);
                  },
                  filename: function (req, file, callback) {
                      callback(null, file.fieldname + '-' +Date.now());
                  }
             });

        upload = multer({ storage : storage}).single(file_name);

        upload(req,res,function(err) {
            if(err) 
                res.send("Error uploading file.");
            else
                res.send("File is uploaded");
            res.end();
        });
    });
}

我的问题是

The console.log(req.body); is returning empty object {}. There is no file.

我想要

To upload the file triggered in Summernote editor to the directory './public'

谁能告诉我缺少什么吗?或者哪里出了问题?

谢谢

最佳答案

尝试this ,一些很好的上传文件的示例。

var express = require('express'),
    multer  = require('multer')

var app = express()
app.use(multer({ dest: './uploads/'}))

app.get('/', function(req, res){
  res.send('hello world');
});

app.post('/', function(req, res){
    console.log(req.body) // form fields
    console.log(req.files) // form files
    res.status(204).end()
});

app.listen(3000);

关于javascript - Summernote 图像 + Node.js (Express.js),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38867615/

相关文章:

javascript - 通过 javascript 将点击值传递给模态

javascript - 无法正确使用json响应

node.js - 增强外部 TypeScript 模块

node.js - Rethinkdb竞争条件创建表

javascript - Angular ng-repeat 有效...但没有绑定(bind)/显示任何值(Twig)

javascript - PHP 无法添加更多行(表单重复器)

jQuery ajax 不会发出 HTTPS 请求

javascript - AngularJS 表单提交不起作用

jquery - 获取页面加载时菜单的高度

javascript - NodeJS 和 Knex - 表不会自动创建