-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathindex.xml
400 lines (297 loc) · 21.3 KB
/
index.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
<channel>
<title>区块链部落</title>
<generator uri="https://gohugo.io">Hugo</generator>
<link>https://ipfs.io/ipns/QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP/</link>
<language>en-us</language>
<author>黎跃春</author>
<copyright>2017 liyuechun</copyright>
<updated>Mon, 30 Oct 2017 20:01:00 UTC</updated>
<item>
<title>【IPFS + 区块链 系列】 入门篇 - IPFS+IPNS+个人博客搭建</title>
<link>https://ipfs.io/ipns/QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP/2017/10/ipfs_first_post/</link>
<pubDate>Mon, 30 Oct 2017 20:01:00 UTC</pubDate>
<author>黎跃春</author>
<guid>https://ipfs.io/ipns/QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP/2017/10/ipfs_first_post/</guid>
<description>
<blockquote>
<p>孔壹学院:国内区块链职业教育引领品牌。</p>
<p>作者:黎跃春,孔壹学院创始人,区块链、高可用架构师</p>
<p>微信:liyc1215</p>
<p>区块链博客:<a href="http://liyuechun.org">http://liyuechun.org</a></p>
</blockquote>
<p>在阅读这篇文章之前,你需要先学习<a href="http://liyuechun.org/2017/11/20/ipfs-blockchain/">【IPFS + 区块链 系列】 入门篇 - IPFS环境配置</a>这篇文章。</p>
<h2 id="目录">目录</h2>
<ul>
<li><a href="#1-如何在IPFS新增一个文件">1. 如何在IPFS新增一个文件</a>
<ul>
<li><a href="#11-新建file.txt文件">1.1 新建file.txt文件</a></li>
<li><a href="#12-查看ipfs相关命令">1.2 查看ipfs相关命令</a></li>
<li><a href="#13-将file.txt添加到ipfs节点">1.3 将file.txt添加到ipfs节点</a></li>
</ul></li>
<li><a href="#2-通过ipfs创建目录存储文件">2. 通过ipfs创建目录存储文件</a></li>
<li><a href="#3-如何在IPFS新增一个目录">3. 如何在IPFS新增一个目录</a>
<ul>
<li><a href="#31-使用ipfs add -r可以上传一整个目录">3.1 使用ipfs add -r可以上传一整个目录</a></li>
<li><a href="#32-通过路径访问contactme.txt文件数据">3.2 通过路径访问contactme.txt文件数据</a></li>
<li><a href="#33-通过Hash查看数据IPFS网络数据">3.3 通过Hash查看数据IPFS网络数据</a></li>
</ul></li>
<li><a href="#4-创建简易的网页发布到IPFS">4. 创建简易的网页发布到IPFS</a>
<ul>
<li><a href="#41-创建一个index.html文件">4.1 创建一个index.html文件</a></li>
<li><a href="#42-创建一个style.css文件">4.2 创建一个style.css文件</a></li>
<li><a href="#43-添加到ipfs">4.3 添加到ipfs</a></li>
<li><a href="#44-网络同步">4.4 网络同步</a></li>
<li><a href="#45-访问网站">4.5 访问网站</a></li>
<li><a href="#46-发布到IPNS">4.6 发布到IPNS</a></li>
</ul></li>
<li><a href="#5-发布个人博客">5. 发布个人博客</a>
<ul>
<li><a href="#51-搭建静态博客">5.1 搭建静态博客</a></li>
<li><a href="#52-节点ID替换">5.2 节点ID替换</a></li>
<li><a href="#53-浏览博客">5.3 浏览博客</a></li>
</ul></li>
<li><a href="#6-下篇预报">6. 下篇预报</a>
<ul>
<li><a href="#61-`ipfs + ethereum``Dapp`开发入门">6.1 <code>ipfs + ethereum</code><code>Dapp</code>开发入门</a></li>
</ul></li>
</ul>
<h2 id="1-如何在ipfs新增一个文件">1. 如何在IPFS新增一个文件</h2>
<h3 id="1-1-新建file-txt文件">1.1 新建file.txt文件</h3>
<p>打开终端,切换到桌面,新建一个文件夹<code>1121</code>,切换到<code>1121</code>中,通过<code>vi</code>新建一个文件<code>file.txt</code>,文件里面输入春哥微信号<code>liyc1215</code>保存并且退出。</p>
<pre><code>localhost:Desktop yuechunli$ pwd
/Users/liyuechun/Desktop
localhost:Desktop yuechunli$ mkdir 1121
localhost:Desktop yuechunli$ cd 1121/
localhost:1121 yuechunli$ vi file.txt
localhost:1121 yuechunli$ cat file.txt
liyc1215
localhost:1121 yuechunli$
</code></pre>
<h3 id="1-2-查看ipfs相关命令">1.2 查看ipfs相关命令</h3>
<pre><code>localhost:1121 yuechunli$ ipfs help
USAGE
ipfs - Global p2p merkle-dag filesystem.
ipfs [--config=&lt;config&gt; | -c] [--debug=&lt;debug&gt; | -D] [--help=&lt;help&gt;] [-h=&lt;h&gt;] [--local=&lt;local&gt; | -L] [--api=&lt;api&gt;] &lt;command&gt; ...
SUBCOMMANDS
BASIC COMMANDS
init Initialize ipfs local configuration
add &lt;path&gt; Add a file to IPFS
cat &lt;ref&gt; Show IPFS object data
get &lt;ref&gt; Download IPFS objects
ls &lt;ref&gt; List links from an object
refs &lt;ref&gt; List hashes of links from an object
DATA STRUCTURE COMMANDS
block Interact with raw blocks in the datastore
object Interact with raw dag nodes
files Interact with objects as if they were a unix filesystem
dag Interact with IPLD documents (experimental)
ADVANCED COMMANDS
daemon Start a long-running daemon process
mount Mount an IPFS read-only mountpoint
resolve Resolve any type of name
name Publish and resolve IPNS names
key Create and list IPNS name keypairs
dns Resolve DNS links
pin Pin objects to local storage
repo Manipulate the IPFS repository
stats Various operational stats
p2p Libp2p stream mounting
filestore Manage the filestore (experimental)
NETWORK COMMANDS
id Show info about IPFS peers
bootstrap Add or remove bootstrap peers
swarm Manage connections to the p2p network
dht Query the DHT for values or peers
ping Measure the latency of a connection
diag Print diagnostics
TOOL COMMANDS
config Manage configuration
version Show ipfs version information
update Download and apply go-ipfs updates
commands List all available commands
</code></pre>
<h3 id="1-3-将file-txt添加到ipfs节点">1.3 将file.txt添加到ipfs节点</h3>
<pre><code>localhost:1121 yuechunli$ ls
file.txt
localhost:1121 yuechunli$ ipfs add file.txt
added QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T file.txt
localhost:1121 yuechunli$ cat file.txt
liyc1215
localhost:1121 yuechunli$ ipfs cat QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T
liyc1215
localhost:1121 yuechunli$
</code></pre>
<p>当执行完<code>ipfs add file.txt</code>这个命令以后,会将<code>file.txt</code>添加到<code>ipfs</code>当前的节点中,并且会对<code>file.txt</code>文件生成一个唯一的<code>hash</code><code>QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T</code>,如果想查看本地<code>ipfs</code>节点的数据,可以通过<code>ipfs cat QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T</code>进行查看。</p>
<p><strong>⚠️:</strong>当我试图通过<code>http://ipfs.io/ipfs/QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T</code>进行数据访问时,无法访问,如下图所示:</p>
<p><img src="http://om1c35wrq.bkt.clouddn.com/fangwen.gif" alt="" /></p>
<p><strong>⚠️:</strong>虽然数据已经添加到当前的你自己的<code>IPFS</code>节点中,但是并没有同步到<code>IPFS</code>网络,所以暂时在网络上无法访问。</p>
<p><strong>⚠️:重要:接下来执行下面的命令同步节点数据到<code>IPFS</code>网络,再试图在网络上查看数据。</strong></p>
<ul>
<li>同步节点</li>
</ul>
<p>新建一个终端,执行<code>ipfs daemon</code>。</p>
<pre><code>localhost:.ipfs yuechunli$ ipfs daemon
Initializing daemon...
Adjusting current ulimit to 2048...
Successfully raised file descriptor limit to 2048.
Swarm listening on /ip4/111.196.246.151/tcp/3637
Swarm listening on /ip4/127.0.0.1/tcp/4001
Swarm listening on /ip4/169.254.170.167/tcp/4001
Swarm listening on /ip4/192.168.0.107/tcp/4001
Swarm listening on /ip6/::1/tcp/4001
API server listening on /ip4/127.0.0.1/tcp/5001
Gateway (readonly) server listening on /ip4/127.0.0.1/tcp/8080
Daemon is ready
</code></pre>
<ul>
<li>从<code>IPFS</code>网络查看数据</li>
</ul>
<p>浏览器访问<a href="https://ipfs.io/ipfs/QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T">https://ipfs.io/ipfs/QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T</a></p>
<p><img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="黎跃春 微信" /></p>
<h2 id="2-通过ipfs创建目录存储文件">2. 通过ipfs创建目录存储文件</h2>
<p>在着上面的步骤走,我们可以通过<code>ipfs cat QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T
liyc1215</code>查看添加到<code>ipfs</code>网络的<code>file.txt</code>文件的内容,如下:</p>
<pre><code>localhost:1121 yuechunli$ ipfs cat QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T
liyc1215
localhost:1121 yuechunli$
</code></pre>
<p>当然,我们也可以通过<code>ipfs</code>的相关命令在<code>ipfs</code>的根目录下面创建文件夹,并且将<code>file.txt</code>文件<strong>移动</strong>或者<strong>拷贝</strong>到我们创建的文件夹中。</p>
<p><strong>⚠️:cp不会改变文件hash,mv会改变hash寻址。</strong></p>
<pre><code>localhost:1121 yuechunli$ ipfs cat QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T
liyc1215
localhost:1121 yuechunli$ ipfs files mkdir /LiYueChun
localhost:1121 yuechunli$ ipfs files cp /ipfs/QmbrevseVQKf1vsYMsxCscRf6D7S2dftYpHwxkYf94pc7T /LiYueChun/file.txt
localhost:1121 yuechunli$ ipfs files ls /
LiYueChun
localhost:1121 yuechunli$ ipfs files ls /LiYueChun/
file.txt
localhost:1121 yuechunli$ ipfs files read /LiYueChun/file.txt
liyc1215
localhost:1121 yuechunli$
</code></pre>
<h2 id="3-如何在ipfs新增一个目录">3. 如何在IPFS新增一个目录</h2>
<h3 id="3-1-使用ipfs-add-r可以上传一整个目录">3.1 使用ipfs add -r可以上传一整个目录</h3>
<pre><code>localhost:1121 yuechunli$ ipfs add -r ipfs-tutorial/
added QmYx4BnhnLXeMWF5mKu16fJgUBiVP7ECXh7qcsUZnXiRxc ipfs-tutorial/contactme.txt
added QmfKdWsguobA3aDPvSxLB3Bq4HMKyqKSgFr2NFUuVH8n31 ipfs-tutorial/eth-fabric.png
added QmXe8jTxTh5MZP6BK5cnj19mXNTKVMzNyUJZUHuYyr5dk1 ipfs-tutorial/gongzhonghao.png
added QmSsjQDVw1fvmG5RsZMgp2GjihiXn2zDv64mfHZN3AREek ipfs-tutorial
</code></pre>
<h4 id="3-2-通过路径访问contactme-txt文件数据">3.2 通过路径访问contactme.txt文件数据</h4>
<p>如果我们上传的是目录,那么可以通过下面几种方式访问到<code>contactme.txt</code>文件的数据。</p>
<pre><code>localhost:1121 yuechunli$ ipfs cat QmYx4BnhnLXeMWF5mKu16fJgUBiVP7ECXh7qcsUZnXiRxc
微信:liyc1215
区块链技术交流群:348924182
公众号:区块链部落
localhost:1121 yuechunli$ ipfs cat /ipfs/QmYx4BnhnLXeMWF5mKu16fJgUBiVP7ECXh7qcsUZnXiRxc
微信:liyc1215
区块链技术交流群:348924182
公众号:区块链部落
localhost:1121 yuechunli$ ipfs cat /ipfs/QmSsjQDVw1fvmG5RsZMgp2GjihiXn2zDv64mfHZN3AREek/contactme.txt
微信:liyc1215
区块链技术交流群:348924182
公众号:区块链部落
localhost:1121 yuechunli$
</code></pre>
<h3 id="3-3-通过hash查看数据ipfs网络数据">3.3 通过Hash查看数据IPFS网络数据</h3>
<ul>
<li><strong>访问目录:</strong><a href="https://ipfs.io/ipfs/QmSsjQDVw1fvmG5RsZMgp2GjihiXn2zDv64mfHZN3AREek">https://ipfs.io/ipfs/QmSsjQDVw1fvmG5RsZMgp2GjihiXn2zDv64mfHZN3AREek</a></li>
</ul>
<p><img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="" /></p>
<ul>
<li><p><strong>通过目录访问文件:</strong><a href="https://ipfs.io/ipfs/QmSsjQDVw1fvmG5RsZMgp2GjihiXn2zDv64mfHZN3AREek/contactme.txt">https://ipfs.io/ipfs/QmSsjQDVw1fvmG5RsZMgp2GjihiXn2zDv64mfHZN3AREek/contactme.txt</a>
<img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="" /></p></li>
<li><p><strong>通过文件hash直接访问:</strong><a href="https://ipfs.io/ipfs/QmYx4BnhnLXeMWF5mKu16fJgUBiVP7ECXh7qcsUZnXiRxc">https://ipfs.io/ipfs/QmYx4BnhnLXeMWF5mKu16fJgUBiVP7ECXh7qcsUZnXiRxc</a></p></li>
</ul>
<p><img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="" /></p>
<h2 id="4-创建简易的网页发布到ipfs">4. 创建简易的网页发布到IPFS</h2>
<p>在这里我先自己写一个简单的网页给大家演示,先在桌面新建一个<code>site</code>文件夹,然后按照下面的步骤在<code>site</code>文件夹中建立<code>index.html</code>和<code>style.css</code>文件。</p>
<h3 id="4-1-创建一个index-html文件">4.1 创建一个index.html文件</h3>
<pre><code>&lt;!DOCTYPE html&gt;
&lt;html lang=&quot;en&quot;&gt;
&lt;head&gt;
&lt;meta charset=&quot;UTF-8&quot;&gt;
&lt;title&gt;Hello IPFS!&lt;/title&gt;
&lt;link rel=&quot;stylesheet&quot; href=&quot;./style.css&quot; /&gt;
&lt;/head&gt;
&lt;body&gt;
&lt;h1&gt;Hello IPFS!&lt;/h1&gt;
&lt;/body&gt;
&lt;/html&gt;
</code></pre>
<h3 id="4-2-创建一个style-css文件">4.2 创建一个style.css文件</h3>
<pre><code>h1 {
color: green;
}
</code></pre>
<h3 id="4-3-添加到ipfs">4.3 添加到ipfs</h3>
<pre><code>localhost:Desktop yuechunli$ ipfs add -r site/
added QmWG5rbgT9H77TGq49RXNoqN8M7DNKMnMX425nkmCB6BjS site/index.html
added QmfGLJ3mryLvicQqzdsghq4QRhptKJtBAPe7yDJxsBGSuy site/style.css
added QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp site
</code></pre>
<p>最后一行是项目根目录的<code>hash</code>,你先通过<code>ipfs daemon</code>同步网络,然后可以通过<code>https://ipfs.io/ipfs/&lt;你的项目根目录hash&gt;</code>,即<code>https://ipfs.io/ipfs/QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp</code>访问项目。</p>
<h3 id="4-4-网络同步">4.4 网络同步</h3>
<pre><code>localhost:Desktop yuechunli$ ipfs daemon
</code></pre>
<h3 id="4-5-访问网站">4.5 访问网站</h3>
<p>浏览器打开<a href="https://ipfs.io/ipfs/QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp">https://ipfs.io/ipfs/QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp</a>,效果图如下:</p>
<p><img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="" /></p>
<h3 id="4-6-发布到ipns">4.6 发布到IPNS</h3>
<p>当我们修改网站内容重新添加到<code>ipfs</code>时,<code>hash</code>会发生变化,当我们网站更新时,我们可以将网站发布到IPNS,在IPNS中,允许我们节点的域名空间中引用一个<code>IPFS hash</code>,也就是说我们可以通过节点<code>ID</code>对项目根目录的<code>IPFS HASH</code>进行绑定,以后我们访问网站时直接通过节点·ID<code>访问即可,当我们更新博客时,重新发布到</code>IPNS`即可。</p>
<pre><code>localhost:~ yuechunli$ ipfs name publish QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp
Published to QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP: /ipfs/QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp
localhost:~ yuechunli$ ipfs id
{
&quot;ID&quot;: &quot;QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP&quot;
}
</code></pre>
<p>当我们执行<code>ipfs name publish</code>命令时,会返回我们的节点<code>ID</code>,你可以通过<code>ipfs id</code>进行查看验证是否是你的节点<code>ID</code>。</p>
<p><strong>⚠️:验证</strong></p>
<pre><code>$ ipfs name resolve &lt;peerId&gt;
</code></pre>
<pre><code>localhost:~ yuechunli$ ipfs name resolve QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP
/ipfs/QmdVEGkT5u7LtzzatTrn8JGNEF3fpuMPVs2rPCfvqRykRp
localhost:~ yuechunli$
</code></pre>
<p><strong>⚠️:</strong>当然我们现在就可以通过<code>IPNS</code>进行访问了。</p>
<pre><code>https://ipfs.io/ipns/QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP
</code></pre>
<p><strong>⚠️⚠️⚠️:注意上面是ipns而不是ipfs。</strong></p>
<p><img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="" /></p>
<p><strong>⚠️:如果你网站数据修改,需要重新发布到IPNS。</strong></p>
<h2 id="5-发布个人博客">5. 发布个人博客</h2>
<p>你可以通过<code>Hugo</code>按照官方文档创建一个漂亮的静态博客<a href="http://gohugo.io/getting-started/quick-start/">Hugo官方网站</a>,当然你也可以自己编写,或者使用其他开源项目搭建。</p>
<h3 id="5-1-搭建静态博客">5.1 搭建静态博客</h3>
<p>大家可以自己搭建,也可以直接下载我的博客源码直接搭建。</p>
<p>源码地址:<a href="http://github.com/liyuechun/ipfs_blogger">http://github.com/liyuechun/ipfs_blogger</a></p>
<h3 id="5-2-节点id替换">5.2 节点ID替换</h3>
<ul>
<li>查看你的节点ID</li>
</ul>
<pre><code>localhost:ipfs_pin yuechunli$ ipfs id
{
&quot;ID&quot;: &quot;《your peer id》&quot;
}
localhost:ipfs_pin yuechunli$
</code></pre>
<p>在上面的源码中全局搜索将源码里面的<code>QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP</code>替换成你自己的<code>ID</code>。</p>
<p>接下来重复<a href="#4-创建简易的网页发布到IPFS">4. 创建简易的网页发布到IPFS</a>的操作步骤即可。</p>
<h3 id="5-3-浏览博客">5.3 浏览博客</h3>
<p>浏览器打开<a href="https://ipfs.io/ipns/QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP/">https://ipfs.io/ipns/QmdKXkeEWcuRw9oqBwopKUa8CgK1iBktPGYaMoJ4UNt1MP/</a>查看项目效果。</p>
<p><img src="http://om1c35wrq.bkt.clouddn.com/[email protected]" alt="IPFS 博客项目效果图" /></p>
<h2 id="6-下篇预报">6. 下篇预报</h2>
<h3 id="6-1-ipfs-ethereum-dapp-开发入门">6.1 <code>ipfs + ethereum</code><code>Dapp</code>开发入门</h3>
<h2 id="7-技术交流">7. 技术交流</h2>
<ul>
<li>区块链技术交流QQ群:<code>348924182</code></li>
<li>进微信群请加微信:<code>liyc1215</code></li>
<li>「区块链部落」官方公众号</li>
</ul>
<p><img src="http://om1c35wrq.bkt.clouddn.com/%E5%8C%BA%E5%9D%97%E9%93%BE%E9%83%A8%E8%90%BD.png" alt="" /></p>
</description>
</item>
</channel>
</rss>