传统的抽奖系统都是运行在单机上,那么这台设备就可能被做过手脚,抽奖的结果也不能令所有人信服。如果能在每个人的设备上都运行一次抽奖的话,这样结果就可以令大家信服了 —— 但显然不能简单地这样做,因为每个人抽出的结果都是不一样的。
于是我想能否利用我在区块链中了解到的「两阶段广播」来产生去中心化的随机数?让这个抽奖程序以分布式的方式运行在所有人的设备上,会有一个后端服务器帮助客户端进行广播,但没有任何特权,每个客户端都会对抽奖过程进行验算,一旦有人作弊就会被发现。
于是我实现了这样一个原型(https://rollup.leanapp.cn,大家可以开两个窗口体验一下),源代码和更详细的算法描述在 https://github.com/jysperm/rollup,不过目前还有一些问题:
- 目前只要有人执意捣乱,那么抽奖将一直都无法完成
- 我还没彻底想清楚如果后端没有公正地进行广播,会有怎样的影响
关于两阶段广播:
- Ethereum 中的随机数生成器 https://github.com/randao/randao
- BlockChain 与 Ethereum 介绍 https://jysperm.me/2016/05/blockchain-slides/
