github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/rpc/client_example_test.go (about) 1 2 //此源码被清华学神尹成大魔王专业翻译分析并修改 3 //尹成QQ77025077 4 //尹成微信18510341407 5 //尹成所在QQ群721929980 6 //尹成邮箱 yinc13@mails.tsinghua.edu.cn 7 //尹成毕业于清华大学,微软区块链领域全球最有价值专家 8 //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620 9 //版权所有2016 Go Ethereum作者 10 //此文件是Go以太坊库的一部分。 11 // 12 //Go-Ethereum库是免费软件:您可以重新分发它和/或修改 13 //根据GNU发布的较低通用公共许可证的条款 14 //自由软件基金会,或者许可证的第3版,或者 15 //(由您选择)任何更高版本。 16 // 17 //Go以太坊图书馆的发行目的是希望它会有用, 18 //但没有任何保证;甚至没有 19 //适销性或特定用途的适用性。见 20 //GNU较低的通用公共许可证,了解更多详细信息。 21 // 22 //你应该收到一份GNU较低级别的公共许可证副本 23 //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。 24 25 package rpc_test 26 27 import ( 28 "context" 29 "fmt" 30 "math/big" 31 "time" 32 33 "github.com/ethereum/go-ethereum/rpc" 34 ) 35 36 //在这个例子中,我们的客户希望跟踪最新的“块号” 37 //服务器已知。服务器支持两种方法: 38 // 39 //eth_getBlockByNumber(“最新”,) 40 //返回最新的块对象。 41 // 42 //ETH订阅(“newblocks”) 43 //创建在新块到达时激发块对象的订阅。 44 45 type Block struct { 46 Number *big.Int 47 } 48 49 func ExampleClientSubscription() { 50 //连接客户端。 51 client, _ := rpc.Dial("ws://127.0.0.1:8485“) 52 subch := make(chan Block) 53 54 //确保Subch接收到最新的块。 55 go func() { 56 for i := 0; ; i++ { 57 if i > 0 { 58 time.Sleep(2 * time.Second) 59 } 60 subscribeBlocks(client, subch) 61 } 62 }() 63 64 //到达时打印订阅中的事件。 65 for block := range subch { 66 fmt.Println("latest block:", block.Number) 67 } 68 } 69 70 //subscribeBlocks在自己的goroutine中运行并维护 71 //新块的订阅。 72 func subscribeBlocks(client *rpc.Client, subch chan Block) { 73 ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second) 74 defer cancel() 75 76 //订阅新块。 77 sub, err := client.EthSubscribe(ctx, subch, "newHeads") 78 if err != nil { 79 fmt.Println("subscribe error:", err) 80 return 81 } 82 83 //现在已建立连接。 84 //用当前块更新频道。 85 var lastBlock Block 86 if err := client.CallContext(ctx, &lastBlock, "eth_getBlockByNumber", "latest"); err != nil { 87 fmt.Println("can't get latest block:", err) 88 return 89 } 90 subch <- lastBlock 91 92 //订阅将向通道传递事件。等待 93 //订阅以任何原因结束,然后循环重新建立 94 //连接。 95 fmt.Println("connection lost: ", <-sub.Err()) 96 }