security - blockchain - audit 自动化的代码审查工具:slither
访问量: 412
refer to:
https://github.com/crytic/slither#how-to-install
slither也是一款contract的代码审查工具。
注意:使用它的前提,是需要把整个项目做个编译。不能编译的项目无法被slither审计。
安装
pip3 install slither-analyzer
一次安装不成功就安装两次。
使用
cd <your-hardhat-project>
slither . # 这个是帧对整个hardhat项目
slither YourContract.sol # 针对某个sol文件的
针对单个文件的结果
如下,可以看到,它是分别把内容列出来的。
// 这里是出现问题的地方
Lock.constructor(uint256) (Lock.sol#10-18) uses timestamp for comparisons Dangerous comparisons: - require(bool,string)(block.timestamp < _unlockTime,Unlock time should be in the future) (Lock.sol#11-14) Lock.withdraw() (Lock.sol#20-27) uses timestamp for comparisons Dangerous comparisons: - require(bool,string)(block.timestamp >= unlockTime,You can't withdraw yet) (Lock.sol#21) Reference: https://github.com/crytic/slither/wiki/Detector-Documentation#block-timestamp Pragma version^0.8.9 (Lock.sol#2) allows old versions solc-0.8.15 is not recommended for deployment
// 这里是需要参考文档的地方。 Reference: https://github.com/crytic/slither/wiki/Detector-Documentation#incorrect-versions-of-solidity
针对多个文件的结果
红色表示 严重的问题, 黄色是中等的问题, 绿色是 可忽略 (优先级特别低)的问题
如下(点击图中的红框中的连接,就可以看到该问题的详细描述和优先级了)
data:image/s3,"s3://crabby-images/457db/457db3e628fa0f566d594297a33735b10cbf00b5" alt=""
data:image/s3,"s3://crabby-images/34e72/34e72d0490a16a7568c173490b7bbbe5feab0303" alt=""
这个是低优先级
data:image/s3,"s3://crabby-images/0d2d7/0d2d736e19ef54a7fa476f0c15336903b6cf79c7" alt=""
data:image/s3,"s3://crabby-images/3e669/3e6695512c0ec9aafa0c9cae26740ab58ce974a0" alt=""