我在ubuntu上使用npm v1.0.104/node 0.6.12 -当我试图通过npm安装任何新模块时,我收到了下面的错误。IO之前使用http,而不是HTTPS &我想知道这是否会导致npm/unsigned certs的问题)。当npm试图解析“https://registry.npmjs.org”URL时,错误就会弹出。有没有办法我可以忽略错误,或者找到/添加证书到可信存储,以便继续使用npm。

任何关于需要做什么来解决问题的见解都将受到感谢(如果可能的话,我更喜欢通过配置来解决问题,而不是重新安装)。

错误:" SSL错误:SELF_SIGNED_CERT_IN_CHAIN"

完整的信息:

npm ERR! Error: SSL Error: SELF_SIGNED_CERT_IN_CHAIN
npm ERR!     at ClientRequest.<anonymous> (/usr/lib/node_modules/npm/node_modules/request/main.js:252:28)
npm ERR!     at ClientRequest.emit (events.js:67:17)
npm ERR!     at HTTPParser.onIncoming (http.js:1261:11)
npm ERR!     at HTTPParser.onHeadersComplete (http.js:102:31)
npm ERR!     at CleartextStream.ondata (http.js:1150:24)
npm ERR!     at CleartextStream._push (tls.js:375:27)
npm ERR!     at SecurePair.cycle (tls.js:734:20)
npm ERR!     at EncryptedStream.write (tls.js:130:13)
npm ERR!     at Socket.ondata (stream.js:38:26)
npm ERR!     at Socket.emit (events.js:67:17)
npm ERR! Report this *entire* log at:
npm ERR!     <http://github.com/isaacs/npm/issues>
npm ERR! or email it to:
npm ERR!     <npm-@googlegroups.com>
npm ERR! 
npm ERR! System Linux 2.6.38-13-generic
npm ERR! command "node" "/usr/bin/npm" "install" "jed"
npm ERR! node -v v0.6.12
npm ERR! npm -v 1.0.104

当前回答

存储库不再支持自签名证书。你需要升级npm。

// Disable the certificate temporarily in order to do the upgrade
npm config set ca ""

// Upgrade npm. -g (global) means you need root permissions; be root 
// or prepend `sudo`
sudo npm install npm -g

// Undo the previous config change
npm config delete ca

// For Ubuntu/Debian-sid/Mint, node package is renamed to nodejs which 
// npm cannot find. Fix this:
sudo ln -s /usr/bin/nodejs /usr/bin/node

为了使用更新后的npm,你需要打开一个新的终端会话。

来源:这最初是对jnylen的回答的编辑。虽然指导方针上写着“欢迎所有建设性的编辑,但请让它们具有实质性”,但编辑被拒绝了,理由是“这次编辑对原始帖子的修改太多;帖子的原意或意图就会丧失。”我猜社区更喜欢一个单独的答案。

其他回答

你需要找到你公司的代理详细信息和你应该使用的npm注册表。 之后,您可以在用户文件夹C:/users/<your_user>下的.npmrc文件中指定相同的内容。

这就是它如何被指定的

registry=https://your_company/npm/registry/
proxy=http://username:password@proxy:port/
https-proxy=http://username:password@proxy:port/

密码是纯文本的,这显然不理想,也许有一种方法可以用npm理解的方式加密它。

npm config set strict-ssl false -g

在全球范围内保存

对我来说,这是一个超级简单的解决方案。我所需要做的就是通过npm config set http -proxy“http://proxyserverurl:port”在npm中设置http -proxy。@somshivam的解决方案也可以,但如果你要通过云管道安装模块,比如Azure DevOps,你不能在npmrc文件中设置代理,否则会失败。

存储库不再支持自签名证书。你需要升级npm。

// Disable the certificate temporarily in order to do the upgrade
npm config set ca ""

// Upgrade npm. -g (global) means you need root permissions; be root 
// or prepend `sudo`
sudo npm install npm -g

// Undo the previous config change
npm config delete ca

// For Ubuntu/Debian-sid/Mint, node package is renamed to nodejs which 
// npm cannot find. Fix this:
sudo ln -s /usr/bin/nodejs /usr/bin/node

为了使用更新后的npm,你需要打开一个新的终端会话。

来源:这最初是对jnylen的回答的编辑。虽然指导方针上写着“欢迎所有建设性的编辑,但请让它们具有实质性”,但编辑被拒绝了,理由是“这次编辑对原始帖子的修改太多;帖子的原意或意图就会丧失。”我猜社区更喜欢一个单独的答案。

把它放在命令之前似乎可以工作NODE_TLS_REJECT_UNAUTHORIZED=0。 NODE_TLS_REJECT_UNAUTHORIZED=0 npm…

最好弄清楚如何使节点将自签名证书视为有效的。由于某些原因,上面的严格ssl建议对我不起作用。如果您了解安全影响并需要临时快速修复,这是我在谷歌搜索错误期间在一些随机github问题中发现的。