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

Jor*_*dan 3 javascript heroku mongoose node.js express

我最近将我的 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.
Run Code Online (Sandbox Code Playgroud)

应用程序.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;

Run Code Online (Sandbox Code Playgroud)

Ali*_*kan 5

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

  • @AjitKumar 我刚刚了解了 Heroku 仪表板中的内置配置变量,基本上我只需要将所有 .env 变量放在那里,然后我可以在代码中引用它们,如何使用 dotenv。对我来说,将私有变量放在 Heroku 中似乎有点不安全。 (2认同)