经过前两篇文字的分析与设计,我们已经可以搭建出一个能够支持多游戏多渠道的聚合SDK服务端,但这只是理想化状态下的一个简化模型。如果接入渠道的逻辑都是按照理想化的简化过程来构建,那么对于支付的请求,我们可以简化成这样几步:

  1. 游戏客户端创建订单。
  2. 游戏客户端(通过TYPESDK客户端)调用渠道lib库中相应接口,发起支付。
  3. 用户在弹出的支付窗口完成支付。
  4. TYPESDK服务端等待渠道服务端的回调,收到回调后通知游戏服务端。
  5. 游戏服务端执行发货动作。

但是显然这个简化流程在实际上线时是不够满足需求的,例如第一步的创建订单,在实践中就是不应该由游戏客户端来完成的。订单的创建和状态管理,都应该由游戏服务端来控制,当然,这个修改需要游戏开发时做好支持。下面我们就来考虑一个常见的流程问题,需要TYPESDK服务端和游戏服务端来共同处理。

默认场景下,多数渠道技术框架的设计都是默认一个游戏只有一个服务器回调地址,并不会考虑一个游戏存在多个区服服,多个回调地址的情况。当然更不需要考虑TYPESDK这种多游戏共用统一回调地址的需求场景。所以我们需要在设计SDK服务端时,让系统可以识别渠道发来的回调订单究竟属于哪个游戏的哪个区服,据此向对应的服务器发送发货通知。

但是如我们所知,接收到不同渠道的回调请求时,我们可以获取到的信息是不固定的,没有统一判断的信息。大多数渠道的回调信息中除了订单本身相关的信息,比如支付金额商品名称之外,最多提供一些诸如用户信息和安全性校验相关的信息。而可以利用的字段,最常见的情况就是只有一个叫扩展信息的字段。

这个扩展信息字段,在不同的渠道文档里有不同的名称,诸如“扩展字段”,“透传字段”,“自定义信息”,“保留信息”等,或者诸如此类的其他名称。这个字段在下订单时从游戏客户端传送给渠道服务端并作为订单的一部分保存起来,渠道不会对其做任何处理,在支付完成时,将它原样回调发给游戏服务端。通常,我们用这个字段传送游戏内部产生的订单号。我们需要这个字段发挥更多作用,比如传递订单的游戏信息,区服信息等等等等。但是,首先网络传输的时候,并不合适传送太长的信息;其次,很多渠道还人为限制了这个字段的长度。比较夸张的,只留给了开发者12位的长度限制,要在这么短的字段里强行塞进各种信息,并不合适。

TYPESDK服务端作为开发者自己搭建的统一接入后台,当然同样可以用来保存我们需要的信息。所以我们可以在TYPESDK服务端里存储一份订单信息,这个信息的主键是游戏服务器创建的内部订单号,而内容则包括订单的一些更详细的信息比如创建时间,订单金额,以及订单回调的区服信息。这样,在收到渠道发来的一份特定订单的回调信息时,就可以简单的根据这份订单的内部订单号获取到对应区服的回调地址了。

游戏区服回调地址可以使用配置的方式保存在TYPESDK服务端,然后根据保存订单的区服信息查询。但是更简单的方案是,在保存订单时,由游戏服务器直接在保存订单的时候将完整的URL作为一个字段,传送给TYPESDK服务端,作为订单的信息直接保存起来。

根据以上的做法,改进后的支付-充值流程如下图所述:

流程说明

  1. 用户点击某商品的购买按钮时,游戏客户端访问游戏服务器

l  每次点击购买均需要访问游戏服务器并创建内部订单号,并非完成完整支付时才创建

  1. 游戏服务端创建内部订单,生成内部订单号并调用TYPESDK服务端的充值信息提交接口
  2. TYPESDK服务端保存订单信息。返回提交处理结果
  3. 游戏服务端将生成的内部订单号返回游戏客户端
  4. 游戏客户端使用内部订单号调用TYPESDK客户端支付接口
  5. TYPESDK客户端调用渠道客户端SDK的API弹出支付窗

l  用户在支付窗完成支付

  1. 渠道SDK客户端提交订单至渠道服务端
  2. 渠道服务端返回充值请求已接受消息至渠道SDK客户端

l  此时充值尚未到帐,充值到帐是一个异步动作。这里返回的消息表示充值动作完成,请求已接受。

  1. 渠道SDK客户端处理请求已接受消息。返回TYPESDK客户端
  2. TYPESDK客户端包装请求已接受消息,返回游戏客户端
  3. 游戏客户端将请求已接受消息通知游戏服务端,修改订单状态

至此就完成了支付流程中的充值这一过程,用户完成了支付金钱给渠道平台。随后渠道平台在确认到帐之后,会异步处理该订单,然后以回调的形式,通知TYPESDK服务端。TYPESDK服务端收到该回调时,就可以根据回调中的内部订单号字段,查询到该订单对应的游戏区服回调地址,并通知对应的游戏服务器了。

回头看我们在本系列文字第一篇里做出的简单充值到帐流程图,就可以将该流程修改如下图所示:

流程说明

  1. 充值订单到帐后,渠道服务端异步通知TYPESDK服务端
  2. TYPESDK服务端根据内部订单号查询该订单信息
  3. TYPE服务端通知游戏服务端发货
  4. 游戏服务端收到发货请求后先保存该请求,立刻返回TYPESDK服务端,表示已收到发货请求。
  5. TYPESDK返回渠道服务端
  6. 游戏服务端异步处理发货逻辑。并通知游戏客户端

这样,我们就比较圆满的解决了这一实际场景中常见的需求。下一章,我们会继续分析这一流程中存在的其他问题,并讨论如何解决。

这个项目已开源,大家有兴趣可以自己研究或者参照项目编写自己的聚合SDK

项目地址:https://code.csdn.net/typesdk_code

项目地址:https://github.com/typesdk

TYPESDK手游聚合SDK服务端设计思路与架构之三:流程优化之订单保存与通知的更多相关文章

  1. TYPESDK手游聚合SDK服务端设计思路与架构之一:应用场景分析

    TYPESDK 服务端设计思路与架构之一:应用场景分析 作为一个渠道SDK统一接入框架,TYPESDK从一开始,所面对的需求场景就是多款游戏,通过一个统一的SDK服务端,能够同时接入几十个甚至几百个各 ...

  2. TYPESDK手游聚合SDK服务端设计思路与架构之二:服务端设计

    在前一篇文中,我们对一个聚合SDK服务端所需要实现的功能作了简单的分析.通过两个主要场景的功能流程图,我们可以看到,作为多款游戏要适配多个渠道的统一请求转发中心,TYPESDK服务端主要需要实现的功能 ...

  3. TYPESDK手游聚合SDK服务端设计思路与架构之四:流程优化之信息安全与订单校验

    有了前文几个步骤的分析和设计,TYPESDK的信息交互流程已经可以正常工作了,但是,这个流程还没有考虑到支付这样的过程中,至关重要的信息安全问题. 在整个交互过程中,游戏服务端,SDK服务端,渠道服务 ...

  4. TYPESDK手游聚合SDK客户端远程开关:渠道支付黑名单

    渠道支付要做开关干嘛用呢?为什么要做这种东西呢? 这个教训来分享一下,我们的游戏上线公测了,59个渠道首发,其中包括了应用宝,UC,360等的大渠道,也包含有一些工会渠道和小渠道,上线后一切正常,但是 ...

  5. 手游聚合SDK开发之远程开关---渠道登入白名单

    白名单有啥好说的呢?无非就是筛选登入,大家第一眼看到就是这个印象,白名单也是有文章的,弄的时机不同会给你带来很不错的收益,注意是收益.还是举例来说,游戏上线前渠道都会做一个预下载,一般提前1-2天,这 ...

  6. 谈反应式编程在服务端中的应用,数据库操作优化,提速 Upsert

    反应式编程在客户端编程当中的应用相当广泛,而当前在服务端中的应用相对被提及较少.本篇将介绍如何在服务端编程中应用响应时编程来改进数据库操作的性能. 开篇就是结论 接续上一篇<谈反应式编程在服务端 ...

  7. 服务端高并发分布式架构 ESB 企业服务总线

    服务端高并发分布式架构演进之路 - 个人文章 - SegmentFault 思否 https://segmentfault.com/a/1190000018626163 ESB 企业服务总线讲解 ht ...

  8. rsync服务端排错思路

    rsync服务端排错思路       rsync服务端排错思路 查看rsync服务配置文件路径是否正确,正确的默认路径为/etc/rsyncd.conf 查看配置文件里host allow,host ...

  9. 移动APP服务端设计开发注意要点

    2014年,移动APP的热度丝毫没有减退,怎么为您的移动端app设计良好的服务器端接口(API)呢? 下面谈谈我个人的一些想法. 2014年,移动APP的热度丝毫没有减退,并没有像桌面软件被WEB网站 ...

随机推荐

  1. Linux:将rhel yum 切换到centos yum

    Red Hat Enterprise Linux Server(RHEL) yum安装软件时This system is not registered with RHN. RHN support wi ...

  2. Windows cmd 长时间不输出新内容 直到按下ctrl + c 取消或者回车的解决办法

    换了一台新电脑, 在使用 ant 拷贝大量文件的时候 cmd 窗口过了很久没有继续输出新的内容,远远超过平时的耗时, 以为已经卡死 按下 ctrl + c 取消, 这时并没有取消, 而是输出了新内容, ...

  3. mono for android 用ISharedPreferences 进行状态保持 会话保持 应用程序首选项保存

    由于项目需要 要保持用户登录状态 要进行状态保持 用途就好像asp.net的session一样 登录的时候进行保存 ISharedPreferences shared = GetSharedPrefe ...

  4. ZooKeeper1 利用虚拟机搭建自己的ZooKeeper集群

    前言:       前段时间自己参考网上的文章,梳理了一下基于分布式环境部署的业务系统在解决数据一致性问题上的方案,其中有一个方案是使用ZooKeeper,加之在大数据处理中,ZooKeeper确实起 ...

  5. 基于Kubernetes在AWS上部署Kafka时遇到的一些问题

    作者:Jack47 转载请保留作者和原文出处 欢迎关注我的微信公众账号程序员杰克,两边的文章会同步,也可以添加我的RSS订阅源. 交代一下背景:我们的后台系统是一套使用Kafka消息队列的数据处理管线 ...

  6. Hadoop2.2.0安装过程记录

    1    安装环境1.1    客户端1.2    服务端1.3    安装准备    2    操作系统安装2.1.1    BIOS打开虚拟化支持2.1.2    关闭防火墙2.1.3    安装 ...

  7. 创建DbContext

    返回总目录<一步一步使用ABP框架搭建正式项目系列教程> 上一篇介绍了<创建实体>,这一篇我们顺其自然地介绍<创建DbContext>. 温故: 提到DbConte ...

  8. ABP框架 - 设置管理

    文档目录 本节内容: 简介 关于ISettingStore 定义设置 setting scope(设置范围) 重写设置定义 获取设置值 服务端 客户端 修改设置 关于缓存 简介 每个应用必需存储一些设 ...

  9. Web网站中利用JavaScript中ActiveXObject对象获取硬件信息(显示器数量、分辨率)从而进行单双屏跳转

    前言:最近这两天工作上,要实现一个功能,在好友阿聪的帮助下,算是比较好的解决了这个需求. B/S的Web网站,需要实现点击按钮时,根据客户端连接的显示屏(监视器)数量进行,单双屏跳转显示新页面. 由于 ...

  10. Oracle---------sql 中取值两列中值最大的一列

    1.表中有A B C三列,用SQL语句实现:当A列大于B列时选择A列否则选择B列,当B列大于C列时选择B列否则选择C列. select (case when a>b then a else b ...