博客
关于我
(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底层概述—1.InnoDB内存结构
查看>>
MySQL底层概述—2.InnoDB磁盘结构
查看>>
MySQL底层概述—3.InnoDB线程模型
查看>>
MySQL底层概述—4.InnoDB数据文件
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
mysql建立索引的几大原则
查看>>
Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
mysql开启bin-log日志,用于canal同步
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>