6DGS云-云邮件解决方案

如何使用6DGS云-云邮件?

第1步:注册帐户


点击上面的按钮,如下图:

如果未注册帐户,请先注册帐户:

注意:一定要使用自己的手机号码注册,否则后续将无法改密。
其中英文名为您的nodeid(亦节点用户ID)--非常重要,建议填写与团队名、公司名相关。

第2步:创建G节点

我们使用第一步注册得到的帐号登录6DGS云控制台,登录后如下图:

我们看到有免费的1GB的G节点额度,这个额度可以立即使用,直接点击【创建G节点】或点击下图菜单:

点击创建G节点链接或菜单,进入创建G节点页面:

按上述内容填写(注意配置只能选择1GB,合约按流程我们先体验COIN-记帐型合约;
token命名可以直接使用自动生成的coin,如果已经创建过coin的G节点,须修改);
COIN币的数量上限可以随便选,这里因为我们仅仅是测试,设置为1个亿;
云服务商是指G节点集群托管所在地,推荐次序为:华为云-百度云-阿里云-腾讯云;
购买数量为月份数量,也就是这个G节点开通的月数,这里因为是免费额度只能选择1个月;
付款方式这里因为余额还没充值(充值了可以使用余额支付),只能选择会员特权(VIP0也是会员,特权为免费1个GB)
上述内容填写完成后,点击【确定购买】,出现下述弹窗:

可以看到需要支付60元,由于使用了会员特权,所以帐户没钱也是可以直接点击【确定购买】,如下图所未:

购买成功后,等待5秒钟,通过【刷新】按钮可刷新出下图数据,代表创建G节点成功:

至此,一个COIN-记帐型合约的G节点已经创建成功!

第3步:熟悉G节点的菜单功能

依据第2步创建了G节点,现在我们找到管理G节点的菜单:

因为刚才创建的这个G节点托管在了华为云,所以我们点击【G节点】华为云也可以找到它

找到它了,下面我们看一下G节点控制台页面的功能,如下图:

其中API接口和API接口密钥,在下页使用/fork等API接口时需要用到;
我们现在看一下如何管理数据,点击【管理】进入链数据管理操作台界面如下图:

注解:操作区【1】重启仅重启进程,【2】重启会更新代码逻辑并重启,
【3】清空cahe是清空状态缓存,清空数据是将链上的数据清除(会重新构建该G节点)
【4】会删除该G节点,删除后在G节点控制台就找不到它了。
对于数据区,我们看到token-id、height、txid、txjson、hash、sign、timestamp即为一个txid交易纪录在token-id这个高度为height上的一行链纪录;
这里值得注意的是,一个txid会分别出现在多个token-id上,代表了tx交易纪录在有关系的token上的六度共识同步!
下面我们使用G节点的API接口来实现helloworld功能,从而了解到G节点发挥作用的过程!

第4步,使用/fork接口API创建token帐户(token-id)

在使用/fork接口之前,先阅读API文档的接口规范,点击查看API接口文档
如下图所示:

这里可以看到,拼接一个可用的API接口,先在G节点控制台拿到API接口地址和接口密钥,如下图:

API接口地址复制到这里:https://c0.6dgs.opencom.cn/node.testphone.coin
API接口密钥复制到这里:appid=10001&secret_key=bfc51077860b2927be95c0807766ca56
按规范拼接API的接口URL:https://c0.6dgs.opencom.cn/node.testphone.coin/fork?appid=10001&secret_key=bfc51077860b2927be95c0807766ca56

这里在【API接口地址】后面添加了/fork?,还有API接口密钥,这样,一个有效的/fork接口地址就生产了。
我们看API文档,/fork接口需要哪些参数,如下图:

使用dst_token,例如dst_token=coin_6dgscloudmail001,API接口拼接如下:
https://c0.6dgs.opencom.cn/node.testphone.coin/fork?appid=10001&secret_key=bfc51077860b2927be95c0807766ca56&token=coin_0000000000000000&dst_token=coin_6dgscloudmail001
返回结果:{"ret":true,"txid":"txid_33XDE5UqPQKy4fqf","token_x":"coin_6dgscloudmail001","public_key":"waW85UyHRudskDzJXdB1vc9KQsZnWZg7BvhwZvtRgt88","private_key":"HW2sREaA3wE9N4Bm2PNWYLCDcGHcHmgocWrwEfZ7JHcG"}
可以看到ret=true,代表fork新帐户调用成功,同时返回token_x=coin_6dgscloudmail001;
这里注意,因为token-id的唯一性,所以多次调用同一个/fork接口URL,创建dst_token=coin_6dgscloudmail001会在第二次调用以后全部返回失败结果如下:
{"ret":false,"msg":"wallet new token failed! "}
意思是:token-id已经存在于G节点中了,所以fork创建该dst_token失败了(不能多次fork同一个目标token-id)。

第5步,使用/op接口mail指令发送邮件

在使用/op接口之前,先阅读接口API文档,点击查看/op的API接口文档
如下图所示:

交易纪录数据结构为:token_x op(sms) token_y opval(phone and code) extra_data ;(非转帐推荐使用assert、config、notice等指令)
一般情况下,除非是send消息,令token_x=coin_0000000000000000(即token_root)
令token_y=coin_6dgscloudmail001(我们使用上面fork接口API创建的token-id)
发送邮件须使用mail指令,并且令opval={"mail_list":"251499600@qq.com","title":"【6DGS云】测试云邮件发送","content":"测试邮件的邮件内容
粗体字","order_number":"your-order-no","version":1}(其中mail_list参数为邮件列表--可多个邮箱群发--以英文分号“;”隔开,title为邮件标题,content为邮件内容,version暂时只能为1,order_number为订单号非必填)

因为在浏览器里直接使用该参数,所以我们进行urlencode转码:转码工具
转码得到opval:%7b%22mail_list%22%3a%22251499600%40qq.com%22%2c%22title%22%3a%22%e3%80%906DGS%e4%ba%91%e3%80%91%e6%b5%8b%e8%af%95%e4%ba%91%e9%82%ae%e4%bb%b6%e5%8f%91%e9%80%81%22%2c%22content%22%3a%22%e6%b5%8b%e8%af%95%e9%82%ae%e4%bb%b6%e7%9a%84%e9%82%ae%e4%bb%b6%e5%86%85%e5%ae%b9%3cbr%2f%3e%3cb%3e%e7%b2%97%e4%bd%93%e5%ad%97%3c%2fb%3e%22%2c%22order_number%22%3a%22your-order-no%22%2c%22version%22%3a1%7d
接口API的URL拼接如下:
https://c0.6dgs.opencom.cn/node.testphone.coin/op?appid=10001&secret_key=bfc51077860b2927be95c0807766ca56&token_x=coin_0000000000000000&token_y=coin_6dgscloudmail001&opcode=mail&opval=%7b%22mail_list%22%3a%22251499600%40qq.com%22%2c%22title%22%3a%22%e3%80%906DGS%e4%ba%91%e3%80%91%e6%b5%8b%e8%af%95%e4%ba%91%e9%82%ae%e4%bb%b6%e5%8f%91%e9%80%81%22%2c%22content%22%3a%22%e6%b5%8b%e8%af%95%e9%82%ae%e4%bb%b6%e7%9a%84%e9%82%ae%e4%bb%b6%e5%86%85%e5%ae%b9%3cbr%2f%3e%3cb%3e%e7%b2%97%e4%bd%93%e5%ad%97%3c%2fb%3e%22%2c%22order_number%22%3a%22your-order-no%22%2c%22version%22%3a1%7d&extra_data=mail-helloworld
得到的返回结果如下:
{"ret":true,"msg":"success","txid":"txid_2whvKkw7GNYi8NG4","token_x":"coin_0000000000000000","token_y":"coin_6dgscloudmail001","x_state":{"token_state_p":"[]","token_state_val":"20","token_height":29,"pre_txid":"txid_21EfrwpDyD5MfHVq","public_key":"yizNoHddKNvchoikGRdrTaqeDJptUh9XvpnRiDfb85vz","token":"coin_0000000000000000"},"y_state":{"token_state_p":"[\"coin_0000000000000000\"]","token_state_val":"0","token_height":1,"public_key":"waW85UyHRudskDzJXdB1vc9KQsZnWZg7BvhwZvtRgt88","token":"coin_6dgscloudmail001"},"x6dgs_cloud_func_ret":{"ret":false,"msg":"send system mail-fee failed"}}
ret=true代表op接口调用和写入数据成功,这里判断短信是否发送成功是通过x6dgs_cloud_func_ret的回参数判断:
如这里所示:"x6dgs_cloud_func_ret":{"ret":false,"msg":"send system mail-fee failed"},意思是系统扣费失败,先充值。

充值帐户余额后,再次点击该URL得到下述结果:
{"ret":true,"msg":"success","txid":"txid_32MwxPRnKD1Hf44J","token_x":"coin_0000000000000000","token_y":"coin_6dgscloudmail001","x_state":{"token_state_p":"[]","token_state_val":"20","token_height":33,"pre_txid":"txid_21EfrwpDyD5MfHVq","public_key":"yizNoHddKNvchoikGRdrTaqeDJptUh9XvpnRiDfb85vz","token":"coin_0000000000000000"},"y_state":{"token_state_p":"[\"coin_0000000000000000\"]","token_state_val":"0","token_height":2,"public_key":"waW85UyHRudskDzJXdB1vc9KQsZnWZg7BvhwZvtRgt88","token":"coin_6dgscloudmail001"},"x6dgs_cloud_func_ret":{"ret":true,"msg":"success"}}
可以看到,"x6dgs_cloud_func_ret":{"ret":true,"msg":"success"}代表已经发送邮件成功。
通过6DGS云控制台的【余额管理】管理,可以看到发送邮件的扣费纪录:

可通过G节点控制台浏览发送纪录,如下图所示:

这里,因为是op操作(opcode=mail),也可通过/chain/opcode可以查询到op接口的每一条邮件指令的发送纪录点击查看/chain接口文档

案例:收到的一封云邮件(图例)

刚才通过上述/op指令(opcode=mail)成功发送了云邮件,邮件内容截图如下:

从图示可以看到邮件内容是支持html文本标记的,这样,你可以构建丰富的邮件展示内容了。

【指引】帮助您分析错误原因的客服联系方式

客服联系方式:
QQ:251499600
手机:17324139805



Copyright © 2012-2019 广州六度共识科技有限公司. All Rights Reserved.
粤ICP备14035184号