javascript - 如何使用 ts-node 加载环境变量?
问题描述
我已经尝试了一些没有成功的实现。
第一次尝试
eval
在 package.json 脚本中使用"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();
}
在上面的例子中,我尝试dotenv.config
在文件的顶部,在 init 中,在你看到的函数中做。它总是抛出关于内容没有获得它需要的环境变量的相同错误。也就是说,如果我记录process.env
并注释掉与此相关的代码,fetchApiData
那么我会看到所有的环境变量。这就是为什么我认为这是一个比赛时间条件,但无法找到与我自己的问题类似的任何东西。
此外,更棘手的是,这是一个必须在 node 和 esnext 环境中工作的自定义脚本。因此,使用我不太喜欢但还没有解决的语法(例如export = someFunction
),我遇到了相当多棘手的导入/导出问题。
解决方案
我是否正确地看到它,您正在尝试使用您使用 env 变量初始化的变量配置 dotenv?我认为这不会成功。Dotenv 的工作是将 env 变量加载到 process.env。您必须尽早在您的应用程序中配置它。
推荐阅读
- flutter - 如何在 Flutter 中创建电子表格
- google-apps-script - 如何发布单个 Google Scripts 函数?
- java - 如何从带有参数的 UI 调用休息时启动 Spring 批处理作业
- jmeter - Jmeter-成功响应后如何在控制器中中断
- python - bytes('\xFF', 'utf-8') 返回
- angularjs - AngularJs ng-options 重复成重复
- mysql - 在 SQL 案例表达式中为“Then”子句返回多个值
- javascript - 按特定属性值对 JavaScript 对象进行排序
- reactjs - 这个逻辑在 JavaScript 中做了什么?
- gradle - Gradle 瞬态依赖