一、FISCO BCOS 智能合约开发概览
FISCO BCOS 是一个国产开源联盟链平台,支持两种类型的智能合约:FISCO BCOS Documentation
-
Solidity 合约:与以太坊兼容,使用 Solidity 语言编写,适用于灵活的业务逻辑开发。
-
预编译合约(Precompiled Contract) :使用 C++ 开发,内置于平台中,性能更高,适用于逻辑固定但需要共识的场景。FISCO BCOS Documentation
此外,FISCO BCOS 提供了 CRUD 合约接口,简化了合约开发过程,降低了开发门槛。FISCO BCOS Documentation+2FISCO BCOS Documentation+2FISCO BCOS Documentation+2
二、Solidity 合约开发
1. 开发工具支持
FISCO BCOS 支持多种开发工具,包括:
-
Remix 在线 IDE:适合快速编写和测试 Solidity 合约。
-
WeBASE 合约 IDE :提供图形化界面,支持合约的编写、编译、部署和调用。FISCO BCOS Documentation
这些工具帮助开发者高效地进行合约开发和调试。FISCO BCOS Documentation
2. 国密算法支持
在国密环境下,FISCO BCOS 对 Solidity 中的 keccak256
或 sha3
指令进行了替换,实际执行的是国密 SM3 算法,以满足国内密码算法的合规要求。
三、KVTable 与 Table 合约接口
FISCO BCOS 提供了两种表结构接口,实现合约逻辑与数据存储的分离:
1. KVTable(键值对表)
KVTable 适用于键值对数据的存储和访问。
接口示例:
solidity
复制编辑
pragma solidity ^0.4.24; contract KVTableFactory { function openTable(string tableName) public constant returns (KVTable); function createTable(string tableName, string key, string valueFields) public returns(int256); } contract KVTable { function get(string key) public view returns (bool, Entry); function set(string key, Entry entry) public returns (int256); function newEntry() public view returns (Entry); } contract Entry { function getInt(string field) public constant returns (int256); function getString(string field) public constant returns (string); function set(string field, int256 value) public; function set(string field, string value) public; }
使用示例:
solidity
复制编辑
pragma solidity ^0.4.24; import "./Table.sol"; contract KVTableTest { KVTableFactory tableFactory; string constant TABLE_NAME = "t_kvtest"; constructor() public { tableFactory = KVTableFactory(0x1010); tableFactory.createTable(TABLE_NAME, "id", "item_price,item_name"); } function set(string id, int256 item_price, string item_name) public returns (int256) { KVTable table = tableFactory.openTable(TABLE_NAME); Entry entry = table.newEntry(); entry.set("id", id); entry.set("item_price", item_price); entry.set("item_name", item_name); return table.set(id, entry); } function get(string id) public view returns (bool, int256, string) { KVTable table = tableFactory.openTable(TABLE_NAME); bool ok; Entry entry; (ok, entry) = table.get(id); if (ok) { return (true, entry.getInt("item_price"), entry.getString("item_name")); } else { return (false, 0, ""); } } }
2. Table(结构化表)
Table 接口提供了类似数据库的 CRUD 操作,适用于结构化数据的存储和管理。FISCO BCOS Documentation
接口示例:
solidity
复制编辑
pragma solidity ^0.4.24; contract TableFactory { function openTable(string tableName) public constant returns (Table); function createTable(string tableName, string key, string valueFields) public returns(int256); } contract Table { function select(string key, Condition condition) public constant returns (Entries); function insert(string key, Entry entry) public returns (int256); function update(string key, Entry entry, Condition condition) public returns (int256); function remove(string key, Condition condition) public returns (int256); function newEntry() public constant returns (Entry); function newCondition() public constant returns (Condition); } contract Entry { function getInt(string field) public constant returns (int256); function getString(string field) public constant returns (string); function set(string field, int256 value) public; function set(string field, string value) public; } contract Condition { function EQ(string field, int256 value) public; function EQ(string field, string value) public; function GT(string field, int256 value) public; function LT(string field, int256 value) public; }
通过 Table 接口,开发者可以实现复杂的数据查询和管理功能。
四、预编译合约(Precompiled Contract)
预编译合约是使用 C++ 开发的合约,内置于 FISCO BCOS 平台中,具有以下特点:FISCO BCOS Documentation
-
高性能:由于是底层实现,执行效率高,适用于对性能要求较高的场景。
-
逻辑固定:适用于逻辑固定但需要共识的场景,例如群组配置等。
-
接口预定义 :合约接口在编译时预先确定,不能动态修改。FISCO BCOS Documentation
预编译合约适用于对性能和安全性要求较高的业务场景。
五、开发建议与最佳实践
-
选择合适的合约类型:根据业务需求选择 Solidity 合约或预编译合约。
-
使用 CRUD 接口:利用 KVTable 和 Table 接口,实现合约逻辑与数据存储的分离,提升系统的可维护性和扩展性。
-
遵循国密标准:在国密环境下,确保使用平台提供的加密算法,满足合规要求。
-
利用开发工具 :充分利用 Remix、WeBASE 等开发工具,提高开发效率。FISCO BCOS Documentation+1FISCO BCOS Documentation+1
六、参考资料
-
FISCO BCOS 智能合约开发文档:智能合约开发 --- FISCO BCOS 2.0 v2.11.0 文档
-
FISCO BCOS 智能合约开发快速入门:FISCO BCOS智能合约开发快速入门 --- FISCO BCOS 2.0 v2.11.0 文档
-
FISCO BCOS 预编译合约开发指南:使用预编译合约 --- FISCO BCOS 2.0 v2.11.0 文档