我是NodeJS的初学者,并且我有一个非常简单的Node / Express应用程序,它使用PostGreSQL作为数据库。我的“ db.js”文件如下所示:
const { Pool } = require('pg');
module.exports = new Pool({
user: 'postgres',
password: 'xxxx',
host: 'localhost',
port: 5432,
database:'gymmanager'
});
当我只在本地运行时,一切工作正常,因此我决定将应用程序部署到Heroku。为此,我使用环境变量创建了一个.env文件用于开发。这是.env文件:
NODE_ENV=dev
DB_USER='postgres'
DB_PASS='xxxx'
DB_HOST='localhost'
DB_PORT=5432
DB_DATABASE='gymmanager'
我已经更改了“ db.js”文件,现在看起来像这样:
if(process.env.NODE_ENV !== 'dev') {
const { Client } = require('pg');
const client = new Client({
connectionString: process.env.DATABASE_URL,
ssl: true
});
client.connect();
module.exports = client;
} else {
require('dotenv').config();
const { Pool } = require('pg');
module.exports = new Pool({
user: process.env.DB_USER,
password: process.env.DB_PASS,
host: process.env.DB_HOST,
port: process.env.DB_PORT,
database: process.env.DB_DATABASE,
rejectUnauthorized: false
});
}
我的应用已部署并在Heroku上流畅运行,但是现在,当我在本地运行'npm start'时,出现以下错误:
(node:12989) UnhandledPromiseRejectionWarning: Error: self signed certificate
at TLSSocket.onConnectSecure (_tls_wrap.js:1491:34)
at TLSSocket.emit (events.js:315:20)
at TLSSocket._finishInit (_tls_wrap.js:933:8)
at TLSWrap.ssl.onhandshakedone (_tls_wrap.js:691:12)
我尝试了几种解决方案...
Ignore invalid self-signed ssl certificate in node.js with https.request?
nodejs - error self signed certificate in certificate chain
但是它们似乎都不起作用。 谁能帮我吗?
先谢谢了。 :)
答案 0 :(得分:1)
您可以在命令行上尝试export NODE_TLS_REJECT_UNAUTHORIZED=0
吗?这将全局设置属性,而不是process.env["NODE_TLS_REJECT_UNAUTHORIZED"] = 0;
将属性设置为特定进程。希望您也执行了npm config set strict-ssl false
。