写点什么

Redpoint Games 推出 NPM 包签名工具

  • 2018-01-18
  • 本文字数:985 字

    阅读完需:约 3 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

Redpoint 推出了 pkgsign,一个 NPM 的软件包签名和验证工具。它旨在确保上传至 NPM 注册表和从 NPM 注册表下载的包的真实性,从而提高安全性。

当你用 NPM 工作时,会出现一个潜在的安全问题,那就是包的作者无法验证。这意味着恶意软件包可以以合法软件的名义得以上传,反过来,任何依赖它的应用程序也可以照常执行这个软件包。

最近发生的一起事件证明了这点。当几个包从 NPM 注册表意外消失时,九个不知名的包被上传,取而代之。虽然这个问题现在已经解决了,但还是有一段空档期,在这期间,不可信的代码会被误用,就如同它们是合法的代码一样。

为了降低这种风险,Redpoint 推出了 pkgsign:

pkgsign 是一个工具,它能为 NPM 和 Yarn 包添加签名并使用已知签名来验证这些包。为了简化操作,pkgsign 还允许使用 PGP 私钥或 keybase.io 来签名包。

在安装 Keybase 和 pkgsign 之后,包作者可以导航到其软件包目录,并发出如下的命令来签署软件包:

pkgsign .在这个过程中,一个“signature.json”文件将被添加到包中,其他用户可以用这个文件来验证作者的真实性。

通过使用 Keybase,签名还可以连接到各种社交媒体帐户,这有助于进一步验证签名者的身份。同时,PGP 签名也是可用的,这意味着作为替代选择,大公司可以生成 PGP 密钥并将其上传到公共域。

要验证当前你正在处理的包的依赖包,你可以再次发出下面这条命令:

pkgsign verify .--full未来还将发布一个“代表签名”的功能。即使依赖项所有者本身未进行签名,这个功能也可以让软件包为其依赖包的内容签名。所以,它能够使包被完全签名。

需要指出的是,由于该工具仍然较新,所以有些软件包仍然没有用它进行签名:

目前 pkgsign 依赖于未签名的包(因为它还比较新!)。当你从 GitHub 或 NPM 安装 pkgsign 时,这些依赖包还不能得到验证。

如果 pkgsign 使用率增长,可能就会改变这一情况,但现在,建议你直接从 GitHub 克隆 pkgsign 项目,以确保你使用的是正确的版本。或者,你可以直接从 NPM 注册表中安装它,而不用签名。

查看英文原文 Redpoint Games Launch NPM Package Signing Tool


感谢冬雨对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2018-01-18 18:001719
用户头像

发布了 34 篇内容, 共 20.7 次阅读, 收获喜欢 47 次。

关注

评论

发布
暂无评论
发现更多内容

2022-Java后端工程师必会知识点-(操作系统)

自然

操作系统 8月月更

Vue是什么?Vue和jQuery

flow

8月月更

Build QEMU RISC-V Linux

贾献华

8月月更

FinClip,助长智能电视更多想象空间

Geek_99967b

小程序

免费的公共WiFi不要乱连,遭中间人攻击了吧?

wljslmz

网络安全 签约计划第三季 8月月更 中间人攻击

从0到1看支付

自然

支付系统 后端开发 支付网关 签约计划第三季

东西向和南北向通信的统一

阿泽🧸

8月月更

FinClip最易用的智能电视小程序

Geek_99967b

小程序

golang写的存储引擎,基于b+树,mmap

Alber

C++面向对象封装特性的实例分析与应用扩展(二)

CtrlX

c c++ 面向对象 后端 8月月更

2022-Java后端工程师面试指南-(Elasticsearch)

自然

Elastic Search 8月月更

系统管理-Linux系统文件查找

Albert Edison

Linux centos linux 文件权限控制 find 8月月更

SRE运维解密-什么是SRE:DevOps模型的具体实践!

董哥的黑板报

DevOps 运维 云原生 SRE Google

gulp

Jason199

js gulp 8月月更

带你造轮子,自定义一个随意拖拽可吸边的悬浮View组件

yechaoa

android 开源 签约计划第三季 8月月更

一文带你了解 Java 中的构造器

踏雪痕

Java 构造函数 8月月更

开源一夏 |如何优化线上服务器

叶秋学长

开源 服务器 8月月更

电商秒杀系统

极客土豆

【CSS】设置文本样式,包括文本颜色、对齐、缩进、行高等

翼同学

CSS HTML5, CSS3 8月月更

FinClip,车载小程序新玩法

Geek_99967b

小程序

【大厂面试真题解析】虾皮 Shopee 后端一面十四问

面试官问

面试 后端 面试题 Shopee 虾皮

6 个你必须明白 Vue3 的 ref 和 reactive 问题(入门篇)

Geek_z9ygea

JavaScript 前端开发 vuejs 8月月更

现网设备兼容SRv6网络演进

穿过生命散发芬芳

8月月更 SRv6

云计算国内外发展现状

阿炜小菜鸡

云计算 8月月更

目标检测的国内外研究现状

阿炜小菜鸡

目标检测 8月月更

目标检测技术研究现状及发展趋势

阿炜小菜鸡

目标检测 8月月更

化算力为战力:宁夏中卫的数字化转型启示录

脑极体

互联网用户账号信息管理规定今起施行:必须严打账号买卖灰产

石头IT视角

AOSP CameraLatencyHistogram的原理与使用

桑榆

Android; 8月月更

收藏-即时通讯(IM)开源项目OpenIM-功能手册

Geek_1ef48b

Redpoint Games推出NPM包签名工具_安全_Andrew Morgan_InfoQ精选文章