简体   繁体   English

Summernote 图片 + Node.js (Express.js)

[英]Summernote image + Node.js (Express.js)

There are too many solutions out there of how Summernote file-upload can be handled in PHP side, but I couldn't find a single decent solution out there which shows how it can be handled in Node.js.有太多关于如何在PHP端处理Summernote 文件上传的解决方案,但我找不到一个像样的解决方案来展示如何在 Node.js 中处理它。

My Javascript我的 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应用程序.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路由.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();
        });
    });
}

MY PROBLEM IS我的问题是

The console.log(req.body); console.log(req.body); is returning empty object {}.正在返回空对象 {}。 There is no file.没有文件。

I WANT我要

To upload the file triggered in Summernote editor to the directory './public'将 Summernote 编辑器中触发的文件上传到目录'./public'

Can anyone please tell me what is missing?谁能告诉我缺少什么? Or where is it going wrong?或者哪里出错了?

Thanks谢谢

Try this , some good working example of uploading files.试试这个,上传文件的一些很好的工作示例。

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);

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM