博客
关于我
(P105)abcbank框架搭建(二):服务端银行交易基类和交易管理类等,时序图
阅读量:403 次
发布时间:2019-03-05

本文共 912 字,大约阅读时间需要 3 分钟。

文章目录

1.服务端银行交易基类和交易管理类等

  • 类如下:
BankSession(与客户端通信)Transaction(银行交易基类)派生类BalanceInquiryChangePasswordCloseAccountDepositOpenAccountQueryAccountHistoryBillQueryDayBillQueryHistoryBillTransferUserLoginWithdrawal	TransactionManager(交易管理类)
  • 自定义协议:先考虑包头和包体的情况,先不考虑包尾。
    数据包总体格式,包体不定长
    在这里插入图片描述
    请求包包头格式
    在这里插入图片描述
    应答包包头格式
    在这里插入图片描述
    错误代码与错误信息对照表
    在这里插入图片描述

2.时序图

  • eg:P105\ABCBank\BankServer\Server.cpp,P105\ABCBank\BankServer\BankThread.cpp,P105\ABCBank\BankServer\BankSession.cpp,P105\ABCBank\BankServer\TransactionManager.cpp

  • 服务端线程运行起来后,数据包的接收,解析等都在Run()方法里面,并在其中创建BankSession对象,让他与客户端进行通信,通过Recv()方法按照包头和包体的自定义的协议接收数据,并把他缓存起来;

    DoAction()用来处理接收到的数据,将BankSession对象传递过来,调用TransactionManager的DoAction,会找到对应的交易对象Transaction对象来执行Execute,这样就避免了很多switch case语句或者if else语句来编写(用的是表驱动编程)。

  • 处理完毕后,BankSession对象就可以销毁掉了。

    在这里插入图片描述

  • eg:P105\ABCBank\BankServer\CMD\UserLogin.cpp

  • 柜员登录的解包

    包体假设是string,其内容是len+字符串内容,eg:包体是“hello”,那么打包进去的内容是5+“hello”。
    在这里插入图片描述
    请求包:包头+包体
    在这里插入图片描述
    应答包:包头+包体,实际上柜员登录的应答包体是空的,实际上打进去的是0
    在这里插入图片描述

转载地址:http://mifzz.baihongyu.com/

你可能感兴趣的文章
MySQL执行计划 EXPLAIN参数
查看>>
MySQL执行计划【explain】,看这一篇就够啦!
查看>>
Mysql执行计划字段解释
查看>>
mysql执行计划怎么看
查看>>
MySQL执行计划解读
查看>>
mysql执行顺序与索引算法
查看>>
mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
查看>>
mysql技能梳理
查看>>
Mysql报错Packet for query is too large问题解决
查看>>
Mysql报错:too many connections
查看>>
MySQL报错:无法启动MySQL服务
查看>>
mysql排序查询
查看>>
Mysql插入数据从指定选项中随机选择、插入时间从指定范围随机生成、Navicat使用存储过程模拟插入测试数据
查看>>
mysql操作数据表的命令_MySQL数据表操作命令
查看>>
mysql支持表情
查看>>
MySQL改动rootpassword的多种方法
查看>>
mysql数据分组索引_MYSQL之索引配置方法分类
查看>>
mysql数据取差,mysql屏蔽主外键关联关系
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>
Mysql数据库 InnoDB存储引擎中Master Thread的执行流程
查看>>