首页 > 解决方案 > .env 文件中的变量的 nestjs 问题

问题描述

我使用 NestJS 框架来构建一个 rest api,我在获取环境变量时遇到了问题。

我有一个带有路径字符串的变量“SMB_SHARE”的 .env,当我将此变量传递给 smb2 libray 的类构造函数时,这会引发错误,环境变量提供的字符串无效。

环境变量是这样的:

SMB_SHARE=\\10.00.0.000\some_path

当我在代码中使用控制台登录时,变量是好的,是一个字符串并且具有正确的字符串值。但是当我将它传递给构造函数时,它会抛出错误。

我将字符串直接传递给构造函数,它工作正常,构造函数的其他环境变量设置正确(如用户名和密码)。只有 SMB_SHARE 变量会引发错误。

我不知道这里有什么问题。有人可以帮我解决这个问题吗?

我展示了一些例子:

constructor(private config: ConfigService) {
    console.log('VAR', config.get<string>('SMB_SHARE'));
    //This show the correctly string variable value

    const share = config.get<string>('SMB_SHARE');

    this.sambaClient = new SMB2({
      share: '\\\\10.00.0.000\\some_path', //WORK
      //share: share, FAIL
      //share: config.get<string>('SMB_SHARE'), FAIL
      //share: process.env.SMB_SHARE, FAIL
      domain: '',
      username: config.get<string>('SMB_USERNAME'),
      password: config.get<string>('SMB_PASSWORD'),
      debug: true,
      autoCloseTimeout: 0,
    })
}

.env 文件是这样的:

SMB_SHARE=\\\\10.00.0.000\\some_path
SMB_USERNAME=user
SMB_PASSWORD=secret

标签: javascriptenvironment-variablesnestjsdotenvnestjs-config

解决方案


很可能,正在发生的事情是 JavaScript 正在逃避额外的\. 当 print 发生时,这是未转义的,所以它看起来很合适(即console.log(process.env.SMB_SHARE)print \\\\10.0.0.0\\some_path,但实际上,变量是 now \\\\\\\\10.0.0.0\\\\some_path)。我最终使用一个名为的文本文件创建了一个模拟,./temp/.env并使用了fs来自 Node 的模块(这是什么dotenv用途,这是什么用途。您可以在文件的(打印)@nestjs/config下方看到,以及两种不同的方法cat用于node读取文件

~/Documents/code                                                               
▶ cat ./temp/.env
HOST=\\\\127.0.0.1:3000\\path


~/Documents/code                                                               
▶ node
Welcome to Node.js v12.18.2.
Type ".help" for more information.
> const { readFileSync } = require('fs');
undefined
> readFileSync('./temp/.env').toString()
'HOST=\\\\\\\\127.0.0.1:3000\\\\path\n\n'
> console.log(readFileSync('./temp/.env').toString())
HOST=\\\\127.0.0.1:3000\\path

这里的解决方案是将您的.env文件更改为您想要传递给配置的确切字符串(可能\\10.0.0.0\some_path


推荐阅读