(P107)abcbank框架搭建(四):MD5类使用,包尾作用和包尾计算方法,密码加密方法IDEA+MD5

本文主要是介绍(P107)abcbank框架搭建(四):MD5类使用,包尾作用和包尾计算方法,密码加密方法IDEA+MD5,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.MD5类使用
    • 2.包尾作用和包尾计算方法
    • 3.密码加密方法IDEA+MD5

1.MD5类使用

  • 网站上的使用的MD5
    在这里插入图片描述

16bit大实际上是32bit大的中间的16个字符
在这里插入图片描述
在这里插入图片描述

  • eg:P107\ABCBank\BankClient\main.cpp
#include "Server.h"
#include "../Public/MD5.h"#include <stdio.h>
using namespace PUBLIC;int main(void)
{//MD5类的使用//MD5 md5;//unsigned char hash[16];输出的是16bytes的哈希字符串//加密的字符串:cppcourse//加密字符串的长度:9//输出的字符串:hash//md5.MD5Make(hash, (unsigned char const *)"cppcourse", 9);//将16bytes的字符串输出为32bytes的字符串//int i;//for (i=0; i<16; ++i)//{//	printf("%0X", hash[i]);//}//printf("\n");return Singleton<Server>::Instance().Start();
}
  • 测试
    在这里插入图片描述

2.包尾作用和包尾计算方法

  • 数据包总体格式,MD5计算的是包头+包体
    在这里插入图片描述

  • 包尾格式
    在这里插入图片描述

  • 包尾计算方法

先用MD5加密算法将包头与包体部分加密得到一个16字节的hash
然后:
for (int i=0; i<8; ++i)
{hash[i] = hash[i] ^ hash[i+8];hash[i] = hash[i] ^ ((cmd >> (i%2)) & 0xff);
}
取hash前8位cmd是数据包的命令,比如登录是CMD_LOGIN

在这里插入图片描述

  • 对等方如何确认他是一个完整的数据包呢?
    对等方取出前面的包头和包体部分,用上面的算法得到一个8位的哈希值,然后与包尾的哈希值相比较,若相等,则整个包是完整的。

  • TCP是可靠的吗?不可靠。
    TCP是基于网际校验和算法来进行校验的,若2个位出现了反转,1变成0,0变成1,那么得到的网际校验和还是正确的,能够校验数据包是完整的。

3.密码加密方法IDEA+MD5

  • 密码加密方法
MD5加密算法是不可逆的,所以不可以用MD5进行加密,即:客户端加密,服务端无法解密
Idea加密是可逆的
有密码的地方都需要加密
unsigned char ideaKey[16];
unsigned char buf[2];
unsigned short cmd = 0x01;
buf[0] = (cmd >> 8) & 0xff;
buf[1] = cmd & 0xff;
MD5 md5;
md5.MD5Make(ideaKey, buf, 2);for (int i=0; i<8; ++i)
{ideaKey[i] = ideaKey[i] ^ ideaKey[i+8];ideaKey[i] = ideaKey[i] ^ ((cmd >> (i%2)) & 0xff);ideaKey[i+8] = ideaKey[i] ^ ideaKey[i+8];ideaKey[i+8] = ideaKey[i+8] ^ ((cmd >> (i%2)) & 0xff);
}char pass[] = "123456";
char encryptedPass[16];Idea idea;
// 加密
// ideaKey用MD5来加密,得到定长的16个字节,初始值encryptedPass不一定是定长的
idea.Crypt(ideaKey,(const unsigned char*)pass, (unsigned char *)encryptedPass, 16, true);// 解密,有了ideaKey和encryptedPass就能解密
char pass2[16];
idea.Crypt(ideaKey, (const unsigned char*)encryptedPass, (unsigned char *)pass2, 16, false);
  • eg:
    P107\ABCBank\BankClient\CMD\UserLogin.cpp
    在这里插入图片描述
    P107\ABCBank\BankServer\CMD\UserLogin.cpp

这篇关于(P107)abcbank框架搭建(四):MD5类使用,包尾作用和包尾计算方法,密码加密方法IDEA+MD5的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1041352

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所