博客
关于我
(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 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
mysql 状态检查,备份,修复
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>