将应用程序部署到 Heroku,ENV 变量不工作

时间:2021-04-10 19:56:48

标签: javascript node.js express heroku mongoose

我最近将我的 node js 应用程序部署到 Heroku,但在让我的应用程序运行时遇到了一些问题。我的应用程序加载但当我尝试登录时它会中断。据我所知,环境变量由于某种原因没有正确加载。 db 变量是从我的 .ENV 文件中获取的字符串,并且是用于连接到 mongo db 的 Monogo URI。出于某种原因,当 heroku 运行它 process.env.MongoURI 是未定义的。有人知道为什么会发生这种情况吗?

我得到的具体错误是。

错误

MongooseError: The `uri` parameter to `openUri()` must be a string, got "undefined". Make sure the first parameter to `mongoose.connect()` or `mongoose.createConnection()` is a string.

App.js

/* eslint-disable no-unused-vars */
/* eslint-disable comma-dangle */
/* eslint-disable no-console */
/* eslint-disable arrow-parens */
const createError = require('http-errors');
const express = require('express');
const expressLayouts = require('express-ejs-layouts');
const path = require('path');
const cookieParser = require('cookie-parser');
const logger = require('morgan');
const mongoose = require('mongoose');
const flash = require('connect-flash');
const session = require('express-session');
const passport = require('passport');
const dotenv = require('dotenv');

dotenv.config();

const indexRouter = require('./server/index');

const port = process.env.PORT || 3000;
const app = express();

require('./server/config/passport')(passport);

// DB Config
const db = process.env.MongoURI;

mongoose.connect(db, { useNewUrlParser: true, useUnifiedTopology: true }) // I beleieve this is the line that is breaking the code.
  .then(() => { console.log('MONGODB Connected'); })
  .catch(err => console.log(err));

app.use(expressLayouts);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use(session({
  secret: 'secret',
  resave: true,
  saveUninitialized: true
}));

app.use(passport.initialize());
app.use(passport.session());

app.use(flash());

app.use((req, res, next) => {
  res.locals.success_msg = req.flash('success_msg');
  res.locals.error_msg = req.flash('error_msg');
  res.locals.error = req.flash('error');
  next();
});

app.use('/', indexRouter);

// catch 404 and forward to error handler
app.use((req, res, next) => {
  next(createError(404));
});

// error handler
app.use((err, req, res, next) => {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

app.listen(port, () => {
  console.log(`Running on port ${port}`);
});

module.exports = app;

2 个答案:

答案 0 :(得分:2)

为此,您可能应该使用 Heroku 的内置环境变量编辑器。

答案 1 :(得分:0)

首先,确保您的 .env 已添加到您的 .gitignore 文件中。当您将项目部署到 heroku 时,它会自动适应新主机上的变量。
查找更多:https://devcenter.heroku.com/articles/node-best-practices#be-environmentally-aware