(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

相关文章

PostgreSQL数据库密码被遗忘时的操作步骤

《PostgreSQL数据库密码被遗忘时的操作步骤》密码遗忘是常见的用户问题,因此提供一种安全的遗忘密码找回机制是十分必要的,:本文主要介绍PostgreSQL数据库密码被遗忘时的操作步骤的相关资... 目录前言一、背景知识二、Windows环境下的解决步骤1. 找到PostgreSQL安装目录2. 修改p

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Conda虚拟环境的复制和迁移的四种方法实现

《Conda虚拟环境的复制和迁移的四种方法实现》本文主要介绍了Conda虚拟环境的复制和迁移的四种方法实现,包括requirements.txt,environment.yml,conda-pack,... 目录在本机复制Conda虚拟环境相同操作系统之间复制环境方法一:requirements.txt方法

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求

MySQL 打开binlog日志的方法及注意事项

《MySQL打开binlog日志的方法及注意事项》本文给大家介绍MySQL打开binlog日志的方法及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、默认状态二、如何检查 binlog 状态三、如何开启 binlog3.1 临时开启(重启后失效)

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的