博客
关于我
(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中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>