本帖最后由 2424546201 于 2024-6-15 11:40 编辑
Golang区块链ERC721合约交互
前言
前段时间无聊的时候,在云端基于开源链-长安链,搭建了一套 4节点 区块链服。用于测试、调试合约使用。
在这基础上,使用长安链 GO-SDK 完成了与链的交互,以及与 CA 服务的交互,将两个服务融合并对外输出标准接口协议。
区块链浏览器
开源
在与链交互的过程中,遇到了诸多坑,这里就不一一阐述了,官方也没提供过多的Demo参考。所以在这里我把与 链 交互的Demo开源出来,
也算是完善一下官方的用例。包含调整后的 ERC721 合约,以及与 CA 服务对接的部分。
目录结构
├── README.md
├── build.bat
├── build.sh
├── chainx # 区块链utils包
│ ├── ca.go
│ ├── client.go
│ ├── conf.go
│ └── node.go
├── contracts
│ └── erc721 # 调整过后的ERC721合约
│ ├── build.sh
│ ├── erc721.go
│ ├── go.mod
│ └── go.sum
├── go.mod
├── go.sum
└── main.go # 主入口
说明
由于长安链搭建起来比较费劲,所以在代码里面与链 交互的连接方面,用的是现有的测试链,如果需要自己搭建区块链,我后期再出相关的教程。
源码内提供核心资料,方便进行调试(仅用于测试)。
- 区块链默认账号(A/B)。
- 区块链浏览器。
- 链ID、链服务RPC地址。
- 管理员账号CA证书。
- CA服务地址、AppId、AppSecret。
# 1.本地运行(在工作目录下打开命令窗口)
go main.go
# 2.打包运行(windows/linux)
windows执行目录下的 `build.bat`,linux 执行目录下的 `build.sh` 即可。
# 3.预览
默认地址:http://localhost:9999
接口
本服务提供交互接口清单如下,只提供了 SSL-NFT 这一个合约的基本的几个方法示例,其他合约方法的调用都是类似的。
接口 |
请求方式 |
参数 |
描述 |
/api/ca/account |
POST |
body:{"accunt":"账号名称"} |
创建区块链账号 |
/api/nft/erc721/balanceOf |
GET |
query: ?account=区块链账号地址 |
cha询账号下资产数量 |
/api/nft/erc721/mint |
POST |
body: {"token_id": "12121212","name": "测试NFT","uri": "","uri_hash": "","description": "","meta_data": "","to": "f2f1ab63d4790f0ffb48402394da91da81c6f591"} |
发行NFT |
/api/nft/erc721/transferFrom |
POST |
body: {"from": "f2f1ab63d4790f0ffb48402394da91da81c6f591","to": "2359b8c95e873acaac6457156ccd31ada74d9a39","token_id": "12121212"} |
转让NFT |
好了,以上就是本帖的全部内容,相关附件在最后面。有问题可以留言一起讨论。
源文件:
chain_demo.zip
(118.21 KB, 下载次数: 6)
|