如何解决如何使用ts-node加载环境变量?
我尝试了一些没有成功的实现。
第一次尝试
在package.json脚本eval
中使用"fetch:data": "eval $(cat .env) ts-node -O '{\"module\":\"commonjs\"}' ./bin/build-api-data.ts"
。
这会导致JSON解析错误,因为eval由于某种原因删除了我的引号。
undefined:1
{module:commonjs}
^
SyntaxError: Unexpected token m in JSON at position 1
第二次尝试
使用dotenv,我在这里遇到的问题是它是一种竞争条件,导致出现如下错误:
$ CANDID_ENV=local ts-node -O '{"module":"commonjs"}' ./bin/build-api-data.ts
/Users/lassiter.gregg/code/candidco-web/node_modules/contentful/dist/webpack:/contentful/contentful.js:49
throw new TypeError('Expected parameter accessToken')
^
TypeError: Expected parameter accessToken
代码示例
import fs from 'fs';
import path from 'path';
import fetchApiData from '../lib/apiData';
import dotEnv from 'dotenv-safe';
const { CANDID_ENV } = process.env;
const isLocalBuild = CANDID_ENV === 'local';
console.log(dotEnv);
const API_DATA_FILENAME = 'api_data.json';
const ensureDirectoryExistence = filePath => {
var dirname = path.dirname(filePath);
if (fs.existsSync(dirname)) {
return true;
}
ensureDirectoryExistence(dirname);
fs.mkdirSync(dirname);
};
const writeData = (filename,data) => {
const filePath = path.join(__dirname,'..','.data',filename);
ensureDirectoryExistence(filePath);
fs.writeFileSync(filePath,JSON.stringify(data));
console.log('API data stored',filePath);
};
const fetchAndStoreApiData = async () => {
console.log('Fetching all API data');
await dotEnv.config({
path: isLocalBuild ? './.env' : `./.env.${CANDID_ENV}`,});
const newData = await fetchApiData();
writeData(API_DATA_FILENAME,newData);
};
const init = async () => {
fetchAndStoreApiData();
};
if (require.main === module) {
init();
}
在上述情况下,我尝试在文件的顶部,init中以及您所看到的函数中进行dotenv.config
。它始终会引发关于无法获得所需的env变量的相同错误。也就是说,如果我登录process.env
并注释掉与fetchApiData
相关的代码,那么我将看到所有环境变量。这就是为什么我认为这是比赛时的状况,但找不到与我自己的问题类似的东西。
此外,令这更加棘手的是,这是一个必须在节点和esnext环境中工作的自定义脚本。因此,我使用我不太喜欢但尚未发现的语法(例如export = someFunction
)遇到了棘手的进出口问题。
解决方法
我是否正确地看到您正在尝试使用用env变量初始化的变量来配置dotenv?我认为这不会解决。 Dotenv的工作是将env变量加载到process.env。您必须尽早在应用中对其进行配置。
此处有更多相关信息:https://www.npmjs.com/package/dotenv
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。