NextJS + Heroku: переменные env не загружаются
Я использую NextJS и Heroku.
По индексу - Первая загрузка возвращает данные, которые я извлек в getInitialProps, но в обычной функции я получаю сообщение об ошибке, потому что env vars отсутствуют.
Когда я перехожу на другую страницу, я получаю ту же ошибку, но когда я обновляюсь, я вижу данные, извлеченные в getInitialProps. Но опять же, в обычной функции я получаю ошибку для отсутствующих переменных env.
Локально это работает. Я попробовал dotenv-webpack, но это не помогает. Я добавил конфигурационные переменные в Heroku.
Есть идеи?
это мой следующий файл.config.js:
const { parsed: localEnv } = require('dotenv').config()
const webpack = require('webpack')
const Dotenv = require('dotenv-webpack')
const path = require('path')
module.exports = {
//target: 'serverless',
webpack(config) {
config.plugins.push(new webpack.EnvironmentPlugin(localEnv))
config.node = {fs: "empty"};
config.plugins = config.plugins || []
config.plugins = [
...config.plugins,
// Read the .env file
new Dotenv({
path: path.join(__dirname, '.env'),
systemvars: true
})
]
return config
},
publicRuntimeConfig: {
ADDRESS: process.env.ADDRESS,
API_TOKEN: process.env.API_TOKEN,
INFURA_API_KEY: process.env.INFURA_API_KEY
}
}
0 ответов
Получил ответ на странице github next.js: https://github.com/zeit/next.js/issues/6533
Я попробовал несколько разных способов, чтобы решить эту проблему.
Настройка среды с помощью dotenv-webpack
не работает для меня То, что работало, устанавливало env
в next.config.js
как это:
const { parsed: localEnv } = require('dotenv').config()
const webpack = require('webpack');
const path = require('path')
module.exports = {
webpack(config) {
config.plugins.push(new webpack.EnvironmentPlugin(localEnv))
config.node = {fs: "empty"};
config.plugins = config.plugins || []
config.plugins = [
...config.plugins,
]
return config
},
env: {
ADDRESS: '0xd6F75293ec795',
API_TOKEN: 'YUBKzlbA2eFmNbkzk',
INFURA_API_KEY: '97eb10aac61799f9e865',
MNEMONIC: 'my not so secret for testing password',
}
}
Вот что у меня сработало (в next.config.js):
if (process.env.NODE_ENV === 'development') {
require('dotenv').config()
}
module.exports = {
env: {
API_URL: process.env.API_URL,
}
}
Это делает API_URL доступным как на клиенте, так и на сервере, в средах разработки и производства.