我正在开发一个基于Ionic + Angular + Cordova+ Node js的移动应用程序。
应用程序通过窗口访问HTTPS服务器。XMLHttpRequest:
module.exports = function request (method, url, body, headers) {
return new Promise(function (resolve, reject) {
var xhr = new window.XMLHttpRequest()
xhr.open(method, url)
xhr.onload = function () {
return resolve({
status: xhr.status,
body: xhr.responseText
})
}
xhr.onerror = xhr.onabort = function () {
return reject(new Error(xhr.statusText || 'XHR aborted: ' + url))
}
Object.keys(headers).forEach(function (header) {
xhr.setRequestHeader(header, headers[header])
})
xhr.send(body)
})
}
要执行此函数,需要在节点环境中插入适当的根 CA。 由于我不控制发出 https 请求的代码,所以我更喜欢一种基于策略/配置的方法,该方法可以在节点 js 中启用额外的根 CA。
我四处搜索,发现节点实际上提供了一个似乎符合我目的的环境变量"NODE_EXTRA_CA_CERTS"。
但我找不到任何关于如何使用这个变量的例子。
我的实现是安装 npm 包 dotenv-webpack。
添加了一个 .env 文件,其中包含配置"NODE_EXTRA_CA_CERTS=./assets/cert/cacert.pem"(相应根 CA 的文件路径)。
我可以验证变量NODE_EXTRA_CA_CERTS是否已成功设置。 然而,它似乎没有任何影响。 由于安全原因,对服务器的访问被拒绝。
所以我的问题:任何人都可以提供一个如何使用变量"NODE_EXTRA_CA_CERTS"的例子吗?
谢谢
因此,您正在谈论的 env 变量是在"系统"级别提供的,因此您不需要在 env 文件中本地定义该变量。
如果要访问该变量,则应在dotenv-webpack上使用以下配置:
Dotenv({
systemvars: true
})
这将允许您访问系统级变量。要访问该变量,您将使用该变量:process.env.NODE_EXTRA_CA_CERTS
。
process
存储有关正在运行的节点进程的信息。env
存储所有环境变量(由dotenv-webpack
填充)。
您可以在此处阅读有关process
全局变量的更多信息:https://nodejs.org/api/process.html