Car*_*ine 6 postgresql node.js npm express
我是 NodeJS 的初学者,我有一个非常简单的 Node/Express 应用程序,它使用 PostGreSQL 作为数据库。我的“db.js”文件如下所示:
const { Pool } = require('pg');
module.exports = new Pool({
user: 'postgres',
password: 'xxxx',
host: 'localhost',
port: 5432,
database:'gymmanager'
});
Run Code Online (Sandbox Code Playgroud)
当我只在本地运行时,一切都工作正常,所以我决定将应用程序部署到 Heroku。为此,我使用我的开发环境变量创建了一个 .env 文件。这是 .env 文件:
NODE_ENV=dev
DB_USER='postgres'
DB_PASS='xxxx'
DB_HOST='localhost'
DB_PORT=5432
DB_DATABASE='gymmanager'
Run Code Online (Sandbox Code Playgroud)
我已经更改了我的“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
});
}
Run Code Online (Sandbox Code Playgroud)
我的应用程序已部署并在 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)
Run Code Online (Sandbox Code Playgroud)
我尝试了几种解决方案...
使用 https.request 忽略 node.js 中无效的自签名 ssl 证书?
但它们似乎都不起作用。谁能帮我?
提前致谢。:)
你能export NODE_TLS_REJECT_UNAUTHORIZED=0在命令行上尝试一下吗?这会全局设置属性,而不是process.env["NODE_TLS_REJECT_UNAUTHORIZED"] = 0;将属性设置为特定进程。希望你也执行npm config set strict-ssl false。
| 归档时间: |
|
| 查看次数: |
25394 次 |
| 最近记录: |