MYKEY Docs
中文English
中文
中文
  • 简介
  • 基于MYKEY的第三方授权登录
    • 验签代码示例
    • 更多MYKEY登录的技术原理和流程
  • 接入MYKEY
    • 多种方式接入MYKEY
    • Mobile H5页面接入
      • ETH
      • EOS
      • JS功能扩展
    • MYKEY Android SDK接入
      • 环境准备
      • 初始化SDK
      • 认证
      • 签名
      • 转账
      • 合约调用
    • MYKEY iOS SDK接入
      • 环境准备
      • 初始化SDK
      • 认证
      • 签名
      • 转账
      • 合约调用
    • Web应用扫码接入
    • SimpleWallet协议接入
    • Deeplink协议接入
  • 深入MYKEY
    • 深入MYKEY账户
    • 类和方法定义
      • Android类
      • iOS类
    • 错误码
    • 识别MYKEY合约充值
      • ETH充值
      • EOS充值
    • MYKEY白皮书
  • KEY ID
    • KEYID ETH合约介绍
      • 创建账户模块
      • 数据存储模块
      • 逻辑模块
      • 逻辑管理模块
    • 账户恢复机制
    • KEYID合约升级流程
    • KEYID合约升级记录
      • ETH
        • KEY ID以太坊合约升级保护期参数调整公告
        • KEY ID以太坊逻辑合约模块升级公告
        • KEY ID以太坊合约升级保护期参数调整公告
        • KEY ID以太坊 AccountLogic/DualsigsLogic 合约升级公告
        • KEY ID以太坊 DappLogic 合约升级公示
  • 开发资源
    • ETH
    • EOS
  • 加入我们
    • 项目提交上架
    • 开发者社区
Powered by GitBook
On this page
  • 使用SimpleWallet跳转MYKEY代码示例
  • 登录和支付
  • 移动端App调用合约时序图
  • 签名

Was this helpful?

  1. 接入MYKEY

SimpleWallet协议接入

PreviousWeb应用扫码接入NextDeeplink协议接入

Last updated 4 years ago

Was this helpful?

使用SimpleWallet跳转MYKEY代码示例

特别注意: Android端SimpleWallet跳转MYKEY时请使用如下代码(设置MYKEY的包名)

try {
    Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));
    intent.setPackage("com.mykey.id");
    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    context.startActivity(intent);
} catch (Exception e) {
    e.printStackTrace();
}

登录和支付

MYKEY遵循SimpleWallet协议实现,详细请见以下文档:

除了支持SimpleWallet规范的登录和支付,MYKEY还额外增强支持了合约和签名的调用。

特别注意: 与其他的EOS账号有所差异,需要在服务端验签时使用Reserved公钥进行验签。

移动端App调用合约时序图

请传递给MYKEY如下的数据,数据格式为json:

// 合约调用数据格式
{
    protocol    string   // 协议名,本协议默认 SimpleWallet
    version     string   // 协议版本信息,如1.0
    action      string   // 操作类型,为 transaction
    dappName    string   // DApp应用名
    dappIcon    string   // DApp应用图标
    desc        string   // MYKEY显示给用户合约调用语义描述
    callback    string   // MYKEY回调DApp的深度链接,e.g. custom://custom.com/contract
    notifyUrl   string   // 合约调用成功通知DAppServer的回调URL接口
    actions [  //合约操作数组,包含转账与非转账合约操作
      { //非转账
          account   string // 合约名
          name      string // 合约方法
          info      string // MYKEY显示给用户的语义化描述
          data      object // 根据合约abi定义所传的参数对象 e.g. {key1: value1, key2: value2 }
      },
      { //转账
          account   string // 合约名
          name      string // 合约方法
          info      string // MYKEY显示给用户的语义化描述
          TransferDataRequest {
            from     string // 转账From
            to       string // 转账To
            quantity string // 转账金额和单位,e.g. "1.0000 EOS"
            memo     string // 链上备注
          }
      }
    ]
    expired        number   // 仅Web二维码模式可用,过期时间,unix时间戳
}

签名

请传递给MYKEY如下的数据,数据格式为json:

// 签名调用数据格式
{
    protocol    string   // 协议名,本协议默认 SimpleWallet
    version     string   // 协议版本信息,如1.0
    action      string   // 操作类型,为 sign
    dappName    string   // DApp应用名
    dappIcon    string   // DApp应用图标
    desc        string   // MYKEY显示给用户签名调用语义描述
    message     string   // 需要签名的内容
    callback    string   // MYKEY回调DApp的深度链接,e.g. custom://custom.com/contract
    notifyUrl   string   // 签名成功通知DAppServer的回调URL接口
    expired     number   // 仅Web二维码模式可用,过期时间,unix时间戳
}
https://github.com/southex/SimpleWallet/blob/master/README_en.md
MYKEY的账号体系