文章目录
- 场景
- 依赖包风险扫描插件——synopsys codesight
- 安装
- 其他工具
- snyk
- 公司提供/允许的工具
- 指定依赖版本
场景
你在一个前端nodejs项目中使用到了好多个依赖包,其中某几个依赖包的某些版本是有风险的。
在项目上线前,你最好修复这些安全风险。这时,你需要一些工具来帮助你:
- 扫描出那些包含风险的依赖包,最好有风险等级(critical/high/medium/low);
- 对于某个含风险的依赖,你需要知道它的哪个版本是无风险的;
- (由于那些含风险的依赖,不一定是直接依赖,可能是间接依赖,所以)你需要知道在一个nodejs项目中如何指定某个依赖的确切的安装版本。
依赖包风险扫描插件——synopsys codesight
https://marketplace.visualstudio.com/items?itemName=SynopsysCodeSight.vscode-codesight
VSCode 中可以搜到这个插件:
注意插件介绍处有提到:Sign up for a free trial of Code Sight and get started in only a couple of minutes.
个人可以通过注册新账号的方式,免费试用一小会这个插件。
长期使用的话,这个服务是收费的。
安装
在 VSCode 插件安装功能中搜索 codesight
,点击安装。
安装成功后会自己弹出以下页面:
需要提供一个你的邮箱,用于接收验证链接。
其他工具
snyk
https://marketplace.visualstudio.com/items?itemName=snyk-security.snyk-vulnerability-scanner
这个插件我还没用过,先留在这里。
公司提供/允许的工具
如果你公司对于要上线的项目有风险扫描这一步,那同时应该会配备扫描工具,用扫描结果来限制你的上线动作(项目上线前必须修改某某问题)。
这个公司已经为之付费过、用于扫描要上线项目的扫描工具,也是你的工具。
指定依赖版本
这一步骤花了我一周时间。
一开始,是通过手动编辑package-lock.json
或npm-shrinkwrap.json
文件中涉及到的依赖的version, resolved, integrity
等。
integrity
的值用npm info xxx@versionNumber
得出(就是依赖包的checksum值)。
由于我掌握了VSCode多处编辑的快捷键,而且要调整版本的依赖数量也不多,很快就可以搞定。
但是要调整版本的依赖数量太多的时候,人工+重复的工作模式只能成为历史,
以下是代码修改量少,工作量更小,出错环节也更少的修改方式:
nodejs前端项目 如何显式指定某个依赖的版本 resolutions 字段 + npm-force-resolutions 插件 package-lock.json