首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Heroku和multer

Heroku和multer
EN

Stack Overflow用户
提问于 2018-09-19 19:47:12
回答 1查看 7.4K关注 0票数 4

我制作了一个webapp,允许你使用multer将一个文件上传到服务器。当服务器在本地运行时,它的工作原理是一样的,但是当我将它部署到Heroku上时,似乎遇到了500个内部服务器错误。

以前有人处理过这个问题吗?

有什么选择吗?

Webapp在这里:https://dupefinder.herokuapp.com/

Github回购公司在这里:https://github.com/ExtDASH/herkodeploy

代码语言:javascript
复制
2018-09-19T19:38:48.310177+00:00 app[web.1]: POST /uploads 500 148 - 181.170 ms
2018-09-19T19:38:48.310830+00:00 app[web.1]: Error: ENOENT: no such file or directory, open 'uploads/csv1537385928295.csv'
2018-09-19T19:38:48.311255+00:00 heroku[router]: at=info method=POST path="/uploads" host=dupefinder.herokuapp.com request_id=ff1aaa34-f36c-49cf-bd4e-4a936fb48a2c fwd="24.52.32.175" dyno=web.1 connect=1ms service=188ms status=500 bytes=404 protocol=https

下面是浏览器中的控制台错误:

代码语言:javascript
复制
main.js:146 POST https://dupefinder.herokuapp.com/uploads 500 (Internal Server Error)
reader.onload @ main.js:146
load (async)
readFile @ main.js:131
invoker @ vue.js:2029
Vue.$emit @ vue.js:2538
click @ VBtn.ts:108
invoker @ vue.js:2029
fn._withTask.fn._withTask @ vue.js:1828

我使用的是XMLHttpRequest POST请求:

代码语言:javascript
复制
readFile: function(){
        const input = document.querySelector('#myFile')
        const reader = new FileReader()
        reader.onload = function() {
            let csvfile = new Blob([reader.result], { type: 'text/csv' })
            app.uploadingFile = true

            const form = new FormData()
            let sendName = input.files[0].name.split(/\W+/g)

            form.append('Ncsv', csvfile, `${sendName[0]}.csv`)
            const xhr = new XMLHttpRequest()
            xhr.open('POST', '/uploads', true)
            xhr.onreadystatechange = function() {
                if(this.readyState == XMLHttpRequest.DONE && this.status == 200) {
                    form.delete('Ncsv')
                }
            }
            xhr.send(form)

        }
        reader.readAsText(input.files[0])

它转到我的app.post文件中的一个server.js路由:

代码语言:javascript
复制
const express = require('express')
const connect = require('connect')
const morgan = require('morgan')
const bodyParser = require('body-parser')
const mongoose = require('mongoose')
const fs = require('fs-extra')
const multer = require('multer')
const getRouter = require('./routes/ourNums')
const nFs = require('./fileSchema.js')
const namesRouter = require('./routes/namesRouter.js')
const computeRouter = require('./routes/computeRouter.js')

// const uploadRouter = require('./routes/uploadRouter') unused for now
const filesRouter = require('./routes/filesRouter')
const path = require('path')



const app = express()

var storage = multer.diskStorage({
destination: function (req, file, cb) {
    fs.ensureFile(file)
    .then(() => {
        console.log('done')
     }
    cb(null, __dirname+'/uploads')
},
filename: function (req, file, cb) {
    var newName = file.originalname.split(/\W+/g)
    var fullName = `${newName[0]}${Date.now()}.csv`
    cb(null, fullName)
},
})



var upload = multer({ storage: storage })

app.use(express.json({limit: '50mb'}))
app.use(bodyParser.urlencoded({extended: false}))
app.use(bodyParser.json())
app.use(bodyParser.json({ limit: '50mb' }))
app.use(morgan('tiny')) //watching for changes
// app.use(express.static(`${__dirname}/client/index.html`))

app.post('/uploads', upload.single('Ncsv'), function (req, res, next) {
var fileName = req.file.filename
nFs.create({
    name: fileName
})
.then(data => res.status(200).send())
.catch(e => {
    req.error = e
    console.log(e)
    next()
})
})

在此之前,我没有使用fs来做任何事情(正如您在这里看到的,fs.ensureFile没有做任何事情来修复500个错误),我只是把它包括进来,这样我就可以使用它了。在本地运行服务器,这是可行的。我点击我的客户端上的上传按钮,它发送任何我选择作为blob的文件,通过multer运行它,并在/server/uploads/目录中创建该文件

编辑:我刚刚尝试使用multer.memoryStorage(),得到了相同的500个内部服务器错误。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-09-19 21:57:16

我不知道为什么你的上传不被保存;你应该能够暂时保存它们。

但这不会长期有效。Heroku的文件系统是短暂的:您所做的任何更改都将在您的dyno下次重新启动时丢失,频繁发生 (至少每天一次)。

Heroku 建议将上载存储在类似于S3的内容上。.这是导游专门使用Node.js完成的。

一旦您将文件存储在S3上,您应该能够使用适当的库或可能通过HTTP检索它们,这取决于如何配置桶。

如果您仍然希望使用multer,请查看multer-s3

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52413227

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档