验证合约的三种方式

Posted 星星两三

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了验证合约的三种方式相关的知识,希望对你有一定的参考价值。

方式一:

使用truffle插件: https://github.com/rkalis/truffle-plugin-verify

truffle run verify 合约名称@合约地址 --network 网络名称 --debug

注意:需要开启VPN,然后给CMD也设置代理,否则CMD无法访问外网会验证失败 (每次新开CMD都要执行)

//cmd设置代理
set HTTP_PROXY=http://127.0.0.1:port
set HTTPS_PROXY=http://127.0.0.1:port

 方式二:

在etherscan上手动上传

1、合约文件如果有导入的外部合约,需要整合成一个文件(truffle插件自动生成)truffle-flattener

生成的可能要去掉多余的License描述,如有多个的话

truffle-flattener x.sol > xx.sol

2、选择部署时正确的编译版本、是否优化

部署使用0.8.1,代码中是0.8.0,在上传时选择任何一个都验证失败,最后选择的是最新的0.8.4版本直接验证成功(就很诡异)

3、如果是有构造函数,需要填写ABI-encode,也可以根据ABI JSON自动生成。,没有就不需要填写

ABI Encoding Service Online for Solidity Smart Contracts by HashEx

方式三:

remix上的etherscan插件

其实跟truffle插件差不多,也是用API Key去请求,前提是你的合约在remix上编译的就比较方便,否则不建议使用。

WiFi攻击的三种方式

WiFi的安全问题已经引起了不少的使用者重视,甚至已经出现草木皆兵的现象。那么黑客到底是如何做到绕过身份验证来获取WiFi使用权的呢?主要有以下三种方式,其中最后一种方式十分简单。

WiFi的安全问题已经引起了不少的使用者重视,甚至已经出现草木皆兵的现象。那么黑客到底是如何做到绕过身份验证来获取WiFi使用权的呢?主要有以下三种方式,其中最后一种方式十分简单。

技术分享图片

1. 伪造MAC地址

很多时候开放网络的身份验证往往就是通过上网设备的MAC地址连同上网凭证一起实现的。但由于设备的MAC地址都容易进行修改,包括智能手机和笔记本电脑等,也就是这种验证方法根本没有安全保障。黑客可以通过ARP扫描技术,找到其他已经连接上该网络的客户端,这样就可得到一个包含所有连接设备的IP地址和MAC地址的完整APR表。然后黑客可以尝试进行检测这些设备是否会产生上网流量,如果是,就非常容易通过网络认证门户身份验证获取WiFi使用权。

技术分享图片

2. 伪造认证页面

这种方式类似于钓鱼,当创建一个伪造身份认证页面后就能迫使正常用户登录该页面进行身份验证,然后黑客就可以盗取他们的上网凭证。毕竟一般开放的wifi网络的所有流量都是一种未经加密的明文数据,这样黑客就能非常方便的进行拦截并篡改网络流量以达到想要做任何事情的目的。

技术分享图片

3. 利用忘记密码方式

其实这种方式十分的简单,就是抓住待身份验证的WiFi在忘记密码时能够提供重置密码服务,这种服务往往需要连接者的手机号码来进行实现,需要能够向填入的手机号码上发送相关新密码,甚至很多时候还需通过电子邮件来发送新密码;在这种情况下就会允许连接客户端的TMAP/POP邮件服务器,也就意味着黑客能够轻松的获取到密码。

技术分享图片

通过上述的三种方式黑客可以轻松的获取到WiFi密码,从而掌控WiFi以达到传播木马病毒的目的,所以小编提醒大家,应该提高对公共WiFi的警惕,避免给自己带来不必要的麻烦,甚至是财产损失。


以上是关于验证合约的三种方式的主要内容,如果未能解决你的问题,请参考以下文章

第111篇 在区块链浏览器上发布合约源码

详解区块链,智能合约,去中心化应用

什么是区块链技术?区块链到底是什么?什么叫区块链?

区块链实战什么是智能合约,如何搭建智能合约环境

石墨烯区块链智能合约

区块链笔记