跳到主要内容
版本:v3

礼包系统开发指南

提示

接入礼包系统之前,需完成应用配置。在 游戏服务 - 应用配置 中可获取 Client ID 和 Server Secret。请妥善保管这些信息,勿传给他人。

开始

礼包系统接入适用于有请求接口能力的游戏,目前尚未提供完全离线的兑换码服务。

根据您的使用场景,您可以灵活对接以下不同兑换接口完成兑换流程。

方式接口名需游戏方校验后台设置的兑换条件需游戏方提供发送道具接口
游戏方校验/api/v1.0/cdk/game/submit-check
游戏方发送/api/v1.0/cdk/game/submit-send
无服务器兑换/api/v1.0/cdk/game/submit-simple
游戏方校验 Web/api/v1.0/cdk/page/submit-check
游戏方发送 Web/api/v1.0/cdk/page/submit-send

接入顺序

  • 完成应用配置获取 Client ID 和 Server Secret 信息。
  • 进入 运营工具-礼包系统-服务器配置 选择性填写游戏方服务器信息并在其中配置发送通知接收地址用来发送相应道具。
  • 创建礼包活动导出兑换码,礼包配置完成准备测试。
  • 根据实际业务场景使用对应兑换接口完成兑换。

兑换流程

兑换流程大致是:

  1. 根据接口文档提交 兑换码配置信息等参数 给兑换接口。
  2. 兑换接口校验数据合法性。
  3. 兑换系统根据业务场景选择是否调用 游戏方提供的二次校验接口
  4. 校验全部通过后根据不同接口判断是否调用 游戏方提供的发送道具接口 完成兑换。

有三种不同的兑换接口可以进行兑换,整体对接流程只要对接其一接口即可完成:

名称描述
游戏方校验如果您将使用服务器对接兑换系统,可以安全地保存密钥信息,并希望每次兑换时能通过您的应用程序来校验是否允许兑换,调用您的接口来发送道具,请使用此流程。
游戏方发送如果您将使用服务器对接兑换系统,可以安全地保存密钥信息,并希望调用您的应用程序接口来发送每次兑换的道具,请使用此流程。
无服务器兑换如果您希望不开发接口完成兑换流程,调用兑换接口后根据返回值来判断是否兑换失败,请使用此流程。

三种兑换场景

游戏方校验

当您请求兑换码 submit-check 接口进行兑换时,兑换系统会核对库存以及提交数据是否正确,兑换系统核对通过后会调用您在后台配置的二次校验接口并将后台设置的条件作为参数传给您来校验。 当您的接口校验通过后会继续将后台配置的奖品内容作为参数调用您的发送道具接口,当发送道具成功完成后本次兑换完成。 游戏方校验泳道图

游戏方发送

当您请求兑换码 submit-send 接口进行兑换时,兑换系统会核对库存以及提交数据是否正确,核对完成后会继续将后台配置的奖品内容作为参数调用您的发送道具接口,当发送道具成功完成后本次兑换完成。 游戏方发送泳道图

无服务器兑换

当您请求兑换码 submit-simple 接口进行兑换时,兑换系统会核对库存以及提交数据是否正确,兑换信息验证通过后本次兑换完成并将后台配置的道具信息返回给您。 无服务器兑换泳道图

对接兑换接口

游戏方二次校验规范

礼包活动在后台配置了自定义兑换条件后,使用带二次校验能力的接口进行兑换时,兑换系统会将此礼包活动的自定义兑换条件发送给游戏方进行二次校验,下图配置会对您在后台配置的接口发起如下请求:

自定义兑换条件

curl --location -g --request POST <后台配置的游戏方二次校验接口地址> \
--header 'Content-Type: application/json' \
--data-raw '{"activity_id":<后台活动ID>,"character_id":<用户ID>,"content":"[{\"condition\":\"level\",\"operate":\"gt\",\"value\":10}]","ext":<兑换提交的ext参数>,"gift_code":<礼包码>,"nonce_str":"abcdc","server_code": <后台配置的code>,"sign":"42d2b58a8cd58b5e63d90524aaf63ef97e04f223","timestamp":1658825322}'

请在校验完成后返回带有特定字段的 JSON 返回值告诉兑换系统校验结果。

{
"status": true,
"errorCode": "字符串类型的错误code"
}

如果您希望返回字段命名风格保持一致也可以使用下划线命名风格返回信息。

{
"status": true,
"error_code": "字符串类型的错误code"
}

如果您并不要求兑换系统知晓兑换的错误信息可以直接返回 非 200 HTTP code 表示兑换失败,或者返回 HTTP code 200 表示兑换成功。 这样就无需按兑换系统的格式来返回信息。

请求参数类型含义
activity_id字符串礼包活动 ID
character_id字符串兑换的用户 ID
content字符串(JSON)后台配置的自定义条件
content.condition字符串自定义条件-key
content.operate字符串关系-详情见其它
content.value字符串自定义条件-value
ext字符串请求接口时传递的数值
gift_code字符串用户此次兑换的礼包码
nonce_str字符串此次请求的随机字符串
server_code字符串服务器 code
sign字符串签名
timestamp数字秒级时间戳
返回参数类型含义
errorCode字符串错误类型,error_code 含义相同,优先取 errorCode
ext字符串(可选)需要透传给发送道具接口的字符串
status布尔值是否校验成功,true 为成功,false 为失败

游戏方发送道具规范

后台设置的物品信息,在兑换系统完成兑换校验后会带上配置的参数请求 游戏方的发送道具接口。下图配置会对您在后台配置的接口发起如下请求: 自定义兑换条件

curl --location -g --request POST <后台配置的游戏方发送道具接口地址> \
--header 'Content-Type: application/json' \
--data-raw '{"activity_id": <后台活动ID>,"character_id":"uid","content":"[{\"name\": \"奖品名称\", \"number\": 2}]","ext":<兑换提交的ext>,"gift_code":"gift_code","nonce_str":"abcdc","server_code":<后台配置的code>,"sign":"fbe23e6f6f5193355b29e9ea2913b1992af56346","check_ext":<二次兑换接口返回的ext>,"timestamp":1658827492}'

同样请在发送完成后返回带有特定字段的 JSON 返回值告诉兑换系统发送道具结果,也可以使用下划线命名返回字段。

{
"status": true,
"errorCode": "字符串类型的错误code"
}

如果您并不要求兑换系统知晓兑换的错误信息可以直接返回 非 200 HTTP code 表示兑换失败,或者返回 HTTP code 200 表示兑换成功。 这样就无需按兑换系统的格式来返回信息。

请求参数类型含义
activity_id字符串礼包活动 ID
character_id字符串兑换的用户 ID
server_code字符串服务器 code
content字符串(JSON)后台配置的自定义奖品
content.name字符串奖品名称
content.number数字奖品数量
ext字符串请求接口时传递的数值
gift_code字符串用户此次兑换的礼包码
nonce_str字符串此次请求的随机字符串
sign字符串签名
check_ext字符串二次校验透传过来的字符串参数
timestamp数字秒级时间戳
返回参数类型含义
errorCode字符串错误类型,error_code 含义相同,优先取 errorCode
status布尔值是否校验成功,true 为成功,false 为失败

无服务器兑换

使用无服务器兑换接口进行兑换时无需游戏方开发校验与发送接口。

但要注意在 后台配置礼包时需创建无服务器礼包

兑换系统在接收到兑换请求后直接将兑换结果返回,游戏根据返回结果判断是否发放道具。

三种兑换接口

二次校验兑换接口

POST /api/v1.0/cdk/game/submit-check

Header Content-Type:application/json

请求参数:

请求参数类型是否必选含义
client_id字符串必传开发者后台 ClientId 信息
gift_code字符串必传这次兑换的兑换码
server_code字符串必传后台配置的服务器 code
character_id字符串必传游戏用户 ID
nonce_str字符串必传随机字符串,建议五位随机字符串
sign字符串必传签名
timestamp数字必传时间戳,单位为秒,有效期为一分钟
ext字符串非必传该字段会原封不动出现在 ext 中传给游戏二次校验接口

请求示例:

curl --location --request POST '<URL>/api/v1.0/cdk/game/submit-check' \
--header 'Content-Type: application/json' \
--data-raw '{"client_id":<后台ClientId>,"gift_code":<这次使用的兑换码>,"server_code":<服务器code>,"character_id":<游戏用户ID>,"nonce_str":<随机字符串>,"sign":<签名>,"timestamp":<时间戳>,"ext": <透传字段>}'

无二次校验兑换接口

POST /api/v1.0/cdk/game/submit-send

Header Content-Type:application/json

请求参数:

请求参数类型是否必选含义
client_id字符串必传开发者后台 ClientId 信息
gift_code字符串必传这次兑换的兑换码
server_code字符串必传后台配置的服务器 code
character_id字符串必传游戏用户 ID
nonce_str字符串必传随机字符串,建议五位随机字符串
sign字符串必传签名
timestamp数字必传时间戳,单位为秒,有效期为一分钟

请求示例:

curl --location --request POST '<URL>/api/v1.0/cdk/game/submit-send' \
--header 'Content-Type: application/json' \
--data-raw '{"client_id":<后台ClientId>,"gift_code":<这次使用的兑换码>,"server_code":<服务器code>,"character_id":<游戏用户ID>,"nonce_str":<随机字符串>,"sign":<签名>,"timestamp":<时间戳>,"ext": <透传字段>}'

无服务器兑换接口

POST /api/v1.0/cdk/game/submit-simple

Header Content-Type:application/json

请求参数:

请求参数类型是否必选含义
client_id字符串必传开发者后台 ClientId 信息
gift_code字符串必传这次兑换的兑换码
character_id字符串必传游戏用户 ID
nonce_str字符串必传随机字符串,建议五位随机字符串
sign字符串必传签名,该签名用 ClientId 代替 Secret

返回参数:

返回参数类型含义
activity_id字符串礼包活动 ID
nonce_str字符串随机字符串
timestamp字符串时间戳
content字符串(JSON)后台配置的自定义奖品
content.name字符串奖品名称
content.number数字奖品数量
sign字符串返回签名,验证返回数据没有被修改
success布尔是否成功

请求示例:

curl --location --request POST '<URL>/api/v1.0/cdk/game/submit-simple' \
--header 'Content-Type: application/json' \
--data-raw '{"client_id":<后台ClientId>,"gift_code":<这次使用的兑换码>,"character_id":<游戏用户ID>,"nonce_str":<随机字符串>,"sign":<签名>,"timestamp":<时间戳>}'

返回示例:

{
"activity_id": "TDS20220928151122U9H",
"content": "[{\"name\": \"奖品\", \"number\": 2}]",
"nonce_str": "0DD4B",
"sign": "5895f87d3dfb5e0918c1b195c015d9284609d122",
"timestamp": 1664354023,
"success": true
}

返回格式

成功返回

{
"success": true,
"messages": "成功"
}

错误返回

返回参数含义
error错误码
message错误大致信息
info详细信息
info.dev_message开发提示
info.hint详细提示
{
"error": 100001,
"message": "输入有误",
"info": {
"dev_message": "",
"hint": "test error"
}
}

请求域名

TapTap 版本域名
国内 taptap.comhttps://poster-api.xd.cn
海外 taptap.iohttps://poster-api.xd.com

签名

游戏方与兑换系统的接口通讯时将使用签名参数作为基础的安全验证,其中 Secret 为后台 游戏服务 - 应用配置 中 Server Secret

提示

为了保证安全性,请勿将 Server Secret 信息放在客户端中使用以防敏感信息泄漏。

计算签名伪代码如下:

sign == sha1(timestamp + nonce_str + secret)

您也可以通过单元测试验证签名计算过程正确与否,如下是 golang 示例:

func TestMakeSign(t *testing.T) {
timestamp := 1655724586
nonceStr := "abcde"
secret := "abc"
sign := MakeSign(int64(timestamp), nonceStr, secret)
assert.Equal(t, sign, "3cb8c38833fa742e7873378faddcbe5b56088482")
//output: 3cb8c38833fa742e7873378faddcbe5b56088482
}

为了 Secret 不存放在客户端中,无服务器兑换返回的签名通过 Client ID 代替 Secret 进行验签

sign == sha1(timestamp + nonce_str + client_id)

Web 嵌入兑换接口

兑换系统提供了一套支持简易图形验证码的兑换接口,用来支持类似 Web 活动页的接入,与上述兑换接口流程相同但区别在于部分请求参数的改变。

获取验证码

提示

验证码有效期为五分钟,失效后请重新获取新的验证码。

GET /api/v1.0/cdk/page/captcha-img

Header Content-Type:application/json

返回参数含义
imgbase64 格式的图片信息
key验证码 key,提交兑换时会需要带上

返回示例:

{
"img": "",
"key": "XfNTN1gQyvA2AcNOu1UN"
}

二次校验网页版

POST /api/v1.0/cdk/page/submit-check

Header Content-Type:application/json

请求参数:

请求参数类型是否必选含义
client_id字符串必传开发者后台 ClientId 信息
gift_code字符串必传这次兑换的兑换码
server_code字符串必传后台配置的服务器 code
character_id字符串必传游戏用户 ID
nonce_str字符串必传随机字符串,建议五位随机字符串
verify_captcha_key字符串必传验证码 KEY
verify_captcha_code字符串必传用户提交的验证码答案
ext字符串非必传该字段会原封不动出现在 ext 中传给游戏二次校验接口

无二次校验网页版

POST /api/v1.0/cdk/page/submit-send

Header Content-Type:application/json

请求参数:

请求参数类型是否必选含义
client_id字符串必传开发者后台 ClientId 信息
gift_code字符串必传这次兑换的兑换码
server_code字符串必传后台配置的服务器 code
character_id字符串必传游戏用户 ID
nonce_str字符串必传随机字符串,建议五位随机字符串
verify_captcha_key字符串必传验证码 KEY
verify_captcha_code字符串必传用户提交的验证码答案

其它

错误码

自定义状态码含义
100001输入有误
100002账号验证失败
100003其它错误
100004验证码输入错误,请重试
100005参数错误
100006超过使用限额
100007超过批次使用限额
100008不在礼包活动时间范围之内
100009暂未开放
100010超出服使用范围
100011点击太快了,手速慢点
100012超出礼包最大兑换次数
100013校验 cdkey 未通过
100014操作的人太多了,服务器正在拼命处理中(限流中)
100015发送道具失败
100016该礼包码无效
100017该礼包码活动无效
100018该活动无法使用此兑换接口
500001服务器故障
500002外部接口校验错误

自定义条件关系表

关系 code含义
lt小于
le小于等于
eq等于
ne不等于
ge大于等于
gt大于

兑换系统出口 IP

如果您配置的接口对请求 IP 有安全限制,请根据需要允许兑换系统的 IP 访问。

TapTap 版本IP
国内 taptap.com59.110.228.98
海外 taptap.io8.214.95.148

常见 FAQ

Q: 兑换参数完备,但请求兑换时返回 403。

A: 请检查您的请求中 header 信息,是否有带上特殊的 User Agent。

Q: 二次校验是需要游戏方请求两次兑换接口吗?

A: 二次校验是您按照规范开发校验接口并将地址配置后台中,由兑换系统去请求。