⚠️ 正式开始前请确保你在身体上和精神上都处于合适的状态,请刻意练习,残酷面对 🆒。为方便检索 The First Web3 URL Intensive CoLearning 简写为 WICL1st,第 2 期即为WICL2nd,第 3 期即为 WICL3rd,以此类推。
⚠️ 报名需要按要求认真填写下面 [ XXX ] 部分,方可通过报名审核,通过审核即可开始自主学习。
-
自我介绍:
我是Antigone,cuit区块链准大三学生,想通过共学计划进一步,学习并参与到web3://这样新兴的协议中。本次共学的笔记会发在我的博客
组队期待:
还在观望,暂无,随时更新。
-
你认为你会完成本次 Web3 URL 的残酷学习吗?
Maybe 80%
-
7 月 8 日 - 7 月 14 日:
-
自我介绍:大家按要求更新上方自我介绍,方面大家互相了解,及后续自由组队方向。
-
Web3 URL 残酷共学频道报道:大家可以自由在残酷共学群里交流分享,互动答疑,根据自身学习阶段情况随时开启自由组队。
-
课前学习:了解残酷共学流程,GitHub 协作共学基础;Web3:// 协议课前学习。
-
-
7 月 15 日 - 7 月 21 日:
- 7 月 15 日 周一晚 8 点- 9 点(北京时间): 第 1 次公开课分享
- 本周共学内容: 涉及 Web3:// 的背景和演进历史;支持 Web3:// 协议的访问方式 (gateway 和 EVM browser)来浏览以太坊上面的数据;熟悉使用 Web3:// 和 EthStorage 早期测试网来部署简单的去中心化网站。
- Homework1: 见课程 PPT。
-
7 月 22 日 - 7 月 28 日
-
7 月 22 日 周一晚 8 点- 9 点(北京时间): 第 2 次公开课分享
-
本周共学内容: 涉及 Web3:// 高级开发工具,包括:在命令行通过 web3curl 来通过 Web3:// 协议下载数据,通过 ethfs-uploader 批量上传网页数据,通过 manual 模式来搭建去中心化多人交互全链网站;及深入理解以太坊的存储模型和 gas 开销等。
-
边学边用实战开发: 根据组队情况自由安排。
-
Homework2: 见课程 PPT。
-
-
7 月 29 日 - 8 月 4 日
- 7 月 29 日 周一晚 8 点- 9 点(北京时间): 第 3 次公开课分享
- 本周共学内容: 涉及实际应用案例分享及未来以太坊基础设施在 Web3:// 的重要作用及开发方向等。
- 边学边用实战开发: 根据组队情况自由安排。
- 结营分享: 具体时间及详情另在「Web3 URL 残酷共学频道」通知。
- 今日学习时间:2h
- 学习内容小结:详情见我的博客,预习了一下slides里的内容,对于web3-url有了一个大致的了解。
预习了一下第一次的 slides,简单的介绍了一下web3://协议
ERC-4804提出了使用RFC 2396 URI来表示一个以太坊消息调用,给予了我们一种直接访问以太坊区块链的方式,也就是web3 url,从此不再需要经过http://或者ipfs的代理。
可以参考下面这张图(直接从slides里扒的链接,可能会没法加载= =)
下面的标识是对应URI的RFC标准,上面的标识是对应了对于区块链中具体寻址的对应。
可以看到web3:// 支持大多数http://的功能,就是对标以太坊生态中的http://,与ipfs://不同的是,web3://是直接对接到链上的,虽然看起来都是去中心化的一种应用层协议,但是ipfs://对接的是共享文件的peer节点,web3://对接的是以太坊或者EVM生态的区块链网络。
slides里提供了两种使用web3:// 协议的方式,一种是火狐浏览器插件,这种访问还是经过了gateway 经过http://代理来实现的访问(看起来只是将请求转换成了url请求发送给gateway),然后就是一个[EVM Browser](https://github.com/web3-protocol/evm-browser) 这个在我仅仅只看Readme的情况下,需要一个https的链接指定rpc,,翻了下源码,还真是http call rpc,,
async #rpcCall(rpcUrl, args) {
if(this.#rpcCallCounters[rpcUrl] === undefined) {
this.#rpcCallCounters[rpcUrl] = 0;
}
this.#rpcCallCounters[rpcUrl]++;
let postData = {
jsonrpc: "2.0",
id: this.#rpcCallCounters[rpcUrl],
method: "eth_call",
params:[
args,
"latest"
]
}
const response = await fetch(rpcUrl, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(postData)
})
if(response.status != 200) {
throw new Error("RPC returned an error HTTP code: " + response.status);
}
const json = await response.json()
if(json.error) {
throw new Error("RPC returned an error: " + json.error.message);
}
if(json.result === undefined || json.result === "" || json.result == "0x") {
throw new Error("No data returned");
}
// We got some data!
return json.result;
}
感觉独立协议的部分应该还是未完全完成的状态?
按照ppt的指引,通过web3://访问
浏览器抓包也能很明显看出还是隐式的使用了https
后面slides还讲了一堆将常规web2应用迁移到web3的例子,展示了web3://代替http://的可能性。
随后 slides里列出了对该erc进行拓展的ERC-5018:实现一个在合约类文件系统的接口给合约访问/上传资源,让合约应用显得更贴近web应用,更加符合常规web应用开发的逻辑。
ERC-6944:希望添加一种请求资源的参数解析模式(erc-4804提出了manual和auto两种,前者并不会自动填充参数,所以应该会产生参数缺失无法成功访问的问题),应该也是为了优化web3网页的体验。
XXX
XXX