簡體   English   中英

快遞中不清楚的錯誤處理

[英]Unclear error handling in express

我有一條接受文件上傳的途徑:

在app.js中

.
.
.
var upload = require('./routes/upload');
.
. 
.
app.use('/upload', upload);
.
.
.

/* Need to start the application with NODE_ENV=production */
app.use(function (err, req, res, next){
    if (res.headersSent) {
        return next(err)
    }
    res.status(500)
    res.render('An error occured while trying to serve your request. Please send us an email if the error recurs.')
});
app.listen(3000);

在routes / upload.js中,我在接受文件並在數據庫中進行輸入之前檢查文件類型。 我還在文件寫入期間檢查錯誤,嘗試通過在handleFileUpload中調用next(err)傳遞給app.js中的錯誤處理程序,如下所示:

var express = require('express');
var router = express.Router();
var path = require('path');
var mysql = require('mysql');
var multer = require('multer');
var fs = require('fs');
var db = require('../database');

var MAGIC_NUMBERS = {
    jpg:  'ffd8ffe0',
    jpg1: 'ffd8ffe1',
    png:  '89504e47'
}

/* Adapted from https://evdokimovm.github.io/javascript/nodejs/expressjs/multer/2016/11/03/Upload-files-to-server-using-NodeJS-and-Multer-package-filter-upload-files-by-extension.html */
function checkMagicNumbers(magic) {
    if (magic == MAGIC_NUMBERS.jpg || magic == MAGIC_NUMBERS.jpg1 || magic == MAGIC_NUMBERS.png)
         return true;
}

function handleFileUpload(req, res, next){
    var upload = multer({
        storage: multer.memoryStorage(),
    }).single('fileUpload');

    upload(req, res, function(err) {
        var buffer   = req.file.buffer;
        var magic    = buffer.toString('hex', 0, 4);
        var filename = req.file.fieldname + '-' + req.file.originalname.replace(/\s+/g,'') + '-' + Date.now() + path.extname(req.file.originalname);

        if (checkMagicNumbers(magic)) {
            fs.writeFile('/uploads/' + filename, buffer, 'binary', function(err) {
                if (err){
                    console.log(err);
                    return next(err);
                }
                else{
                    req.savedfilename = filename;
                    next();
                }
            })
        } else {
            res.end('File is not of the following accepted types: jpeg, jpg, png.');
        }
    });
}

function handleDatabaseInsert(req, res, next)
{   
    db.insertRecord(req.body.name, req.body.email, req.body.message,
         req.body.country, req.savedfilename, function(err, results){
            if(err)
                next(err);
    });
    res.end("Thank you for your participation! Please look forward to our email with updates.");
}

/* POST to Upload */
router.post('/', handleFileUpload, handleDatabaseInsert)

module.exports = router;

問題是當我試圖捕獲嘗試寫入文件並將其從handleFileUpload內部傳遞到app.js中的錯誤處理程序時可能發生的錯誤時,將調用下一個中間件handleDatabaseInsert而不是我制作的錯誤處理程序在我讓應用程序監聽之前,在app.js末尾使用該應用程序。

這是預期的行為嗎? 我以為會調用帶有4個形式參數的函數來處理錯誤?

注意:我故意使用不存在的文件路徑來模擬寫入錯誤,在這種情況下,使用/ uploads /而不是./uploads/

謝謝!

如果我理解正確,那么如果發生某種錯誤,您想停止該請求。 為此,您只需停止調用next()

調用next()運行創建的下一個中間件函數。如果您不希望它運行下一個中間件,則不要調用next()

您可能想要執行諸如res.send(500)來代替next()或類似的操作。

如果要創建錯誤處理程序,也可以這樣做:

http://expressjs.com/en/guide/using-middleware.html#middleware.error-handling

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM