文章目录• 摘要• 动机• 原理• 详述• 合约• Function• Event• Parameter• ParameterType• EntryPoint摘要应用程序二进制接口(ABI)是两个程序模块之间的接口,其中一个通常是库和/或操作系统,另一个通常是由程序员创建的应用程序。本NEP描述了NEO智能合约的ABI标准动机NEO智能合约系统旨在在合同之间相互调用。为实现这一目标,我们需要一种机制来公开智能合约的接口。使用NeoContract ABI,开发人员可以轻松的创建程序来调用智能合约或编写能自动访问合同功能的客户端。原理我们假设应用程序二进制接口(ABI)是强类型的,在编译时已知且静态。其不会提供内省机制。我们主张所有合同都具有其在编译时可以调用的合约的接口定义此详述不涉及其接口是动态的或仅在运行时可知的合约。如果这些案例十分重要,可以适当的提出作为特殊构建在NEO的生态体系中。详述合约NeoContract ABI以Json格式定义定义,包含以下结构体,并且某些顶层对象可以包含数个子对象:{“hash”: “0x562851057d8afbc08fabc8c438d7cc771aef2195”,“entrypoint”: “main”,“functions”: [],“events”: []}hash是合约的脚本哈希。它采用16进制字符按大端序编码Entrypoint 代表合约函数的入口functions 是一个函数对象数组,用于描述合约中每个函数的细节events 是一个事件对象数组,用于描述合约中没给事件的细节Function函数对象包含以下结构:{“name”: “transfer”,“parameters”: [],“returntype”: “Boolean”}name代表函数的名称,可以是任何有效的标识符。parameters是一个参数对象数组,用于描述函数中每个参数的详细信息returntype代表函数的返回类型。可以是以下任意一种值:Signature, Boolean, Integer, Hash160, Hash256, ByteArray, PublicKey, String, Array, InteropInterfaceEvent事件对象包含以下结构体{“name”: “refund”,“parameters”: []}name代表事件的名称,可以是任何有效的标识符。parameters是一个参数对象数组,用于描述事件中每个参数的详细信息Parameter参数对象包含以下结构体:{“name”: “from”,“type”: “Hash160”}name代表参数的名称,可以是任意有效字符type代表参数类型。可以是以下任意一种值:Signature, Boolean, Integer, Hash160, Hash256, ByteArray, PublicKey, String, Array, InteropInterfaceParameterType参数类型有以下值:名称 描述Signature A signature of a transaction or block which is generated by the user.Boolean 布尔值的值是true或者false.Integer An arbitrarily large integer whose value in theory has no upper or lower bounds.Hash160 160比特的整型.Hash256 256比特的整型.ByteArray 字节数组.PublicKey 采用压缩模式的ECC公钥.String 采用UTF-8编码的字符串.Array 对象数组. 其元素类型可以是参数类型中的任何一种.InteropInterface 返回互操作服务的接口.Void Void 意味着函数没有返回值. 该值不是参数类型中的任何一种.EntryPoint强烈建议每个合约具有以下入口函数:{“name”: “main”,“parameters”: [{“name”: “operation”,“type”: “String”},{“name”: “args”,“type”: “Array”}],“returntype”: “ByteArray”}通过这种方式,调用者可以从入口点轻松的访问函数,通过第一个参数指定调用函数的名称,通过第二个参数指定函数的的参数原文链接:https://github.com/neo-projec…