今日,比特币又迎来了新的进展,Core开发者LukeDashjr宣布了Knots0.19.1.knots20200304客户端的发布。
关于新客户端更新的内容,你可以在这里找到:https://github.com/bitcoinknots/bitcoin/blob/v0.19.1.knots20200304/doc/release-notes.md
而摆在我们面前的问题是,如何验证自己下载的客户端是安全的,而不是经恶意篡改的呢?当然,确保从可信网站下载是必须的,那我们又如何确保该可信网站没有被攻击者篡改呢?
这也是本文要讲的内容,原文作者是LukeDashjr。
以下是译文:
期望
以下的说明,要求你了解文件在计算机中的存储方式,以及懂得如何使用命令行来运行程序和访问文件。如果你不了解这些概念,请先从指南开始入手。
请注意,本文的说明只能帮你安全地安装比特币客户端,其并不会帮助你保护你的硬件、操作系统,或者避免安装其它引入恶意软件的应用。通常,如果计算机的其他地方受到威胁,则无论你如何验证自己安装的客户端,你的节点也会受到威胁。
数据:昨日BTC暴跌后20952枚比特币从币安转出:Glassnode数据显示,昨日BTC暴跌后的10分钟内,20952枚比特币从币安交易所转出。[2021/4/19 20:36:39]
如果你想要一个绝对安全的节点,除了本文提到的说明之外,你至少还需要避免使用后门硬件,而仅运行可信任的基于Linux的操作系统,仅安装或使用你的操作系统供应商提供的软件,或使用GnuPG进行了其他验证的软件,并确保该软件更新到最新的漏洞修复版本。
即使您无法解决这些问题,因此无法获得最大的安全性,但这也不意味着你应该放弃:无论如何,验证比特币节点软件仍然是一个好主意。
概述
要确保你所安装的比特币客户端是安全的,有三个重要的步骤:
验证OpenPGP密钥;
验证签名;
验证文件本身;
每个步骤都取决于先前的步骤是否成功,虽然我们可以跳过一个步骤,但重要的是要了解,除非所有步骤都成功,否则我们就相当于没有对安装进行验证。
请注意,举例来说,我将在用于ppc64leLinux的?Bitcoin?Knotsv0.19.0.1.knots20200104客户端上验证我自己的签名,而要验证其他人的签名或其他文件,你需要更改命令行以使用该指纹或文件名。
步骤0:安装加密软件GNUPrivacyGuard
数据:持有比特币的账户正从鲸鱼账户转向较小的实体:Glassnode数据显示,持有比特币的账户正从所谓的鲸鱼转变为较小的实体。持有10 BTC以下的实体在5年内从5.1%上升到13.8%。同期持有100至100k BTC的实体从62.9%下降至49.8%。[2020/8/8]
在开始之前,你需要确保自己已安装了GNUPrivacyGuard工具,这是文件的加密验证所需的。
如果你运行了一个基于Linux的系统,通常可通过操作系统供应商那进行安装,你可以通过运行gpg--version进行检查。如果没有,请尝试使用以下命令之一进行安装:
apt-getinstallgnupg
dnfinstallgnupg2
yuminstallgnupg2
emergeapp-crypt/gnupg
pacman-Sgnupg
apkaddgnupg
如果您不幸使用的是Windows或macOS操作系统,则可以从官方网站下载GnuPG,但我不知道有任何安全的方式可以验证这种下载,当然,它们确实提供了签名,但这里就遇到了鸡与蛋的问题:在你安装好的副本之前,你无法验证这些签名!
步骤1:验证OpenPGP密钥
可以说,这一步是验证过程中最困难的部分:你需要确认你实际使用的密钥,是你信任之人所发布的正确密钥。如果你不小心,可能会得到一个假冒的“LukeDashjr”密钥!
动态 | 对冲基金及大型交易商押注比特币下跌:据金十报道,即便比特币价格已经升至10000美元上方,对冲基金和大型交易商正在增加押注比特币下跌的空头头寸;CTFC报告显示,上周对冲基金和货币经理人在CME比特币期货合约中增加了14%的比特币空头仓位,而其他较大规模的交易商持有的比特币空头仓位则为多头头寸的三倍多。[2019/6/25]
每个OpenPGP密钥都有一个“指纹”,即40个十六进制字符,有时会显示空格,以便于阅读。如果你确保使用的密钥指纹与受信任签名者的指纹匹配,则你知道自己拥有了正确的密钥。
获取密钥或指纹
验证密钥最安全的方法,就是亲自见面,并确认密钥“指纹”。几乎没有人记得他们的密钥指纹,所以我们可能不得不在自己的笔记本电脑或手机上查找,偶尔可能会有“密钥签署方”,一群人在会议上确认其他人的指纹,每个参与者要么亲自朗读自己的指纹,要么手动确认每个人看到的或听到的都是正确的。如果你机会参与这样的会议,这是一个好的方法来一次性验证很多密钥。
如果你不感兴趣或没有机会亲自见面,理想情况下应该从多个来源验证密钥。有时,会议会发布演示视频,其中的密钥指纹可能会显示在幻灯片中。当然,由于“deepfake”这些新技术的存在,要注意视频中的幻灯片是容易被操纵的。
开发人员通常会在他们的网站上发布他们的密钥或指纹,也许还有其他一些途径。
如果你已经安装你了你信任的软件副本,有时它会包含验证更新所需的密钥。
中国社会科学院法学研究所副研究员赵磊:认定比特币是金融局是不合理的:4月24日消息,日前,中国社会科学院法学研究所副研究员赵磊发文,深度讨论了比特币的法律属性。其在文中表示,比特币自出现以来,被很多人质疑其不过是一种新型的庞氏局(Ponzi Scheme)或者金字塔式(Pyramid Scheme)而已。不过,赵磊认为从比特币的运行机理以及实际效果来看,其并非庞氏局。他还表示,在金融领域,投资风险大、市场价格畸高畸低的投资比比皆是,因此而认定比特币是金融局是不合理的。[2018/4/24]
检查密钥文件的指纹
要查看密钥文件的指纹,你可以使用以下命令:
gpg--import-optionsshow-only--import--with-fingerprintluke-jr.asc
这将输出有关密钥文件的许多信息,而相关信息位于最上面:
pubrsa81922012-03-23
E463A93F5F3117EEDE6C7316BD02942421F4889F
在本示例中,
E463A93F5F3117EEDE6C7316BD02942421F4889F就是我的密钥指纹。
注意:如果GPG提示密钥过期了,那可能也没有关系!在步骤2中,你将更新到同一密钥的最新版本,这通常会延长到期日期。
雅虎联合创始人对比特币持乐观态度:据了解,雅虎联合创始人Jerry Yang表示对比特币的未来持乐观态度。他表示:“作为数字货币的比特币还不够。就我个人而言,我相信数字货币可以在我们的社会中扮演一个角色......但是现在看来,它更像是投资和获取回报的炒作,而不是把它当作交易货币。”[2017/12/7]
导入已验证的密钥
无论你如何验证密钥,都应该确保记住你使用的是哪个密钥,以便将来更新时可验证使用的是同一个密钥。即使你跳过了验证密钥步骤,至少这将确保你的更新有相同的签名者。
当你确信自己拥有的密钥是正确的时候,你可以这样导入它:
gpg--import<luke-jr.asc
或者如果你只有指纹,像这样:
gpg--keyserverhkp://keyserver.ubuntu.com--recv-keyE463A93F5F3117EEDE6C7316BD02942421F4889F
步骤2:验证签名
现在你知道要用什么密钥进行验证了,下一步就是检查签名是否有效。
在继续此步骤之前,必须确保签名者密钥的副本是最新的。如果你不这样做,你可能会收到一条关于密钥已过期的消息。运行:
gpg--keyserverhkp://keyserver.ubuntu.com--refresh-keyE463A93F5F3117EEDE6C7316BD02942421F4889F
接下来,你将需要两个文件:包含文件指纹列表的“
.assert”文件和包含该列表签名的“
.assert.sig”文件。这是因为我们所做的不是对程序文件本身进行签名,而是对所有文件进行指纹识别,然后对该列表进行签名。因此,这两个文件你都是需要的。
BitcoinCore的“assert”文件对发布在这里:https://github.com/Bitcoin-Core/gitian.sigs/find/master;
BitcoinKnots的“assert”文件对发布在这里:https://github.com/bitconinkots/gitian.sigs/find/Knots
注意,每个签名者都有一个单独的文件对。如果你正在验证是否有多个人签名了你的文件,则需要检查每个文件对。此外,你还需要确保自己正在获取要验证的版本的文件!
在列表中找到所需文件后,单击链接在浏览器中打开该文件,然后右键单击“Raw”或“Download”按钮并选择“链接另存为”。
一旦你有了这两个“assert”文件,你就可以通过运行来检查签名
gpg--verifybitcoin-core-linux-0.19-build.assert.sig
如果这步成功了,你就会得到下面的结果:
gpg:SignaturemadeSun19Jan202003:47:15AMUTC
gpg:usingRSAkeyE463A93F5F3117EEDE6C7316BD02942421F4889F
gpg:Goodsignaturefrom“LukeDashjr<luke@dashjr.org>”
注意密钥的指纹是粗体显示的。该指纹必须要和你在步骤1中验证的密钥匹配,否则它可能是由其他人签名的!关于“好签名”的部分也很重要,而名字和电子邮件地址却不重要,如果指纹是错误的,这两个都可能是伪造的。
假设一切顺利,你现在知道“.assert”文件是由所述密钥的控制者提供担保的,并且可继续验证你的实际程序文件,是否是该“.assert”文件中列出的。
步骤3:验证文件本身
要验证程序文件,必须首先对其进行加密哈希验证。
这是通过一个简单的命令完成的:
Linux:sha256sumbitcoin-0.19.0.1.knots20200104-powerpc64le-linux-gnu.tar.gz
Windows:certUtil-hashfilebitcoin-0.19.0.1.knots20200104-win64.zipSHA256
macOS:shasum-a256bitcoin-0.19.0.1.knots20200104-osx-unsigned.dmg
这将输出如下内容:
d370692590c4546ac0de250da91c6c288d9ee5252f1a4b857a5b80c4e3d81149bitcoin-0.19.0.1.knots20200104-powerpc64le-linux-gnu.tar.gz
这是文件内容的指纹,后跟指定的文件名。
现在,在任何纯文本编辑器/查看器中打开“.assert”文件,并查找该指纹。它应该在顶部的“out_manifest”部分,如果你到达了“in_manifest”或“base_manifests”,那么你已经走得太远了。
如果你在“.assert”文件中找到了它,那么你已经验证了你拥有的文件,是与签名者所担保的文件是相同的。
而如果“.assert”文件中缺少该文件,则可能表示你使用了错误的“.assert”文件,或者你的文件是不匹配的。如果文件已列出,但有着不同的指纹,请不要打开文件,而是保存它,并与受影响项目的安全团队联系。
原创:五火球教主 最近几天,仿佛又让人找回2019年初时的感觉,各大平台蓄势待发,大饼毫无动静。非常巧合的是,这次,又是币安率先"出招",熟悉的配方,熟悉的味道.
1900/1/1 0:00:00作者:EdwardIftody译者:平川来源:区块链前哨导语:?如果我在21世纪初就进行了合理规模的投资,那么我早就退休了。如今,我坚信从长远来看,投资颠覆性企业、专注未来是一个非常好的选择.
1900/1/1 0:00:00在上一期的减半介绍文中大星给新来的同学抛出了知识点比特币减半造成影响最大的一群人可能就是矿工了 对于个体矿工来说减半意味着首先,区块奖励减少了其次.
1900/1/1 0:00:00据NewsBTC2月15日报道,加密货币交易所Kraken表示,持有100至1000枚比特币的“鲸鱼们”正在囤更多的比特币.
1900/1/1 0:00:00据Bitcoinist3月7日报道,法国法院的判决承认了了比特币的价值,并表明比特币可以像货币一样用于赔偿.
1900/1/1 0:00:00过去一周,全球股市经历了12年来最糟糕的一周,而随着这场股市崩盘的发生,加密货币市场也受到了严重的打击.
1900/1/1 0:00:00