经过前两篇文字的分析与设计,我们已经可以搭建出一个能够支持多游戏多渠道的聚合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. openresty 前端开发入门四之Redis篇

    这章主要演示怎么通过lua连接redis,并根据用户输入的key从redis获取value,并返回给用户 操作redis主要用到了lua-resty-redis库,代码可以在github上找得到 而且 ...

  2. IT持续集成之质量管理

    研发工具生态 质量相关工作 一次编译产出测试包与上线包 !从源头保证版本的⼀一致性!代码质量控制! 全⽅方位的⾃自动化测试体系保证! 提测冒烟效率! 全⾃自动上线流程杜绝⼈人⼯工犯错! 生产环境应⽤用 ...

  3. SAP CRM 用户界面对象类型和设计对象

    在CRM中的用户界面对象类型的帮助下,我们可以做这些工作: 进行不同的视图配置 创建动态导航 从设计层控制字段标签.值帮助 控制BOL对象的属性的可视性 从导航栏访问自定义组件 一个用户界面对象类型之 ...

  4. Android之解析XML

    1.XML:可扩展标记语言. 可扩展标记语言是一种很像超文本标记语言的标记语言. 它的设计宗旨是传输数据,而不是显示数据. 它的标记没有被预定义.需要自行定义标签. 它被设计为具有自我描述性. 是W3 ...

  5. 命名sql数据集

    所谓的命名sql其实也就是数据库里的sql语句,普元EOS里做了一定的封装,以方便在程序中的使用. 命名SQL的基本元素包括: 1. <parameterMap> parameterMap ...

  6. 【QQ红包】手机发抢不到的口令红包

    这方法95%的人都抢不了 在QQ输入框输入一个表情,例如:阴险那个表情 将表情剪切到口令红包的口令里 这时候口令里的那个表情表情变成了符号 将符号删去一格,然后全选.复制 然后返回到QQ输入框粘贴 然 ...

  7. 图形数据库Neo4J简介

    最近我在用图形数据库来完成对一个初创项目的支持.在使用过程中觉得这种图形数据库实际上挺有意思的.因此在这里给大家做一个简单的介绍. NoSQL数据库相信大家都听说过.它们常常可以用来处理传统的关系型数 ...

  8. AngularJS 第三天----作用域

    作用域的概念及其功能 AngularJS使用作用域的概念来充当数据模型的作用,在视图和控制器之间起着桥梁的作用.由于双向绑定的数据特性,视图的修改会更新 $scope,同样对 $scope的修改也会重 ...

  9. [Mahout] 完整部署过程

    概述        Mahout底层依赖Hadoop,部署Mahout过程中最困难的就是Hadoop的部署      本文假设用户本身没有进行Hadoop的部署,记述部署Mahout的过程       ...

  10. [WPF]控件应用多个样式

    最近在做WPF项目,公司没有专门的UI工程师,什么都要自己做.接触WPF已经有好几年了,自定义样式什么的也可以做一些.WPF在使用样式的时候一般都是 Style="{StaticResour ...