博客
关于我
(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不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>