前言

MD5消息摘要算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码散列函数,可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输完整一致。MD5由美国密码学家罗纳德·李维斯特(Ronald Linn Rivest)设计,于1992年公开,用以取代MD4算法。1991年,Rivest开发出技术上更为趋近成熟的md5算法。它在MD4的基础上增加了"安全-带子"(safety-belts)的概念。虽然MD5比MD4复杂度大一些,但却更为安全。这个算法很明显的由四个和MD4设计有少许不同的步骤组成。在MD5算法中,信息-摘要的大小和填充的必要条件与MD4完全相同。Den boer和Bosselaers曾发现MD5算法中的假冲突(pseudo-collisions),但除此之外就没有其他被发现的加密后结果了。

目前MD5广泛应用于一致性验证同,数字签名,安全访问认证等用途,

对MD5算法简要的叙述可以为:MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。 总体流程如下图所示, 表示第i个分组,每次的运算都由前一轮的128位结果值和第i块512bit值进行运算:

好了,下面开始进入正题。

示例详解

基于硬件平台: 正点源子的stm32f4 探索者开发板,MCU 的型号是 STM32F4ZET6, 使用stm32cubemx 工具自动产生的配置工程,使用KEIL5编译代码。本示例所用的开发板及部分原理图:

  1. 关于CUBEMX工具及KEIL工具的操作将不再细讲,如果还有不熟悉的可以查看之前的教程文档。下面直接介绍工程配置:
  1. 系统时钟树

  1. 串口配置(用于程序调试)

  1. RCC配置

  1. SYS配置

  1. 引脚配置,用到引脚极少

  1. 堆栈配置(也可保持默认):

  1. 工程代码

    1. 将事先准备好的MD5.c 文件加入工程,并将MD5.h文件放到工程INC文件夹下,这些文件可以在Lwip协议栈中提取,当然百度也能百度得到:

  1. 在main.c 中main函数中USER CODE BEGIN Includes、 USER CODE1、USER CODE 2, USER CODE 4 区域加入如下图所示代码:

 

c) 编译工程,调试程序, (注:在使用探索者F4调试时,下载或仿真调试时先不要PC串口工具连接上开发板的USB_232接口,有可能导致程序运行不了--boot0引脚电平不对,可以先跑起来再在PC串口工具上连接相应端口!!,可按下面的具体操作步骤来操作—>>  )

串口已打开,程序全速运行(F5或单击全速运行图标)相看运行结果:

这个时候可以在串口中看到如下程序运行结果:

到此本次的MD5实验就顺利完成了,从本次实验可以看到,MD5的算法使用还是比较简单的,只需用到MD5Init,MD5Update和MD5Final三个接口即可,简单方便。其中MD5Init为初始化接口,MD5Update为计算接口,MD5Final为获得结果接口。作为MD5的使用,会用这三个接口即可。该工程算法可直接移植到M0,M3等其它内核心MCU同样适用。

OK,本期实验完成!下期见!同时如果大家有什么疑问或是有想了解的其它内容,也欢迎大家留言!!最后喜欢这个公众号的同学们记得加关注了,会有不定期技术干货推出!!

文中源码资料下载,在公众号里给十三发消息:

下载|STM32基础系列教程47

关注十三公众号

STM32 基础系列教程 47 - MD5相关推荐

  1. STM32 基础系列教程 50 – MbedTls

    前言 mbed TLS(以前称为PolarSSL)是TLS和SSL协议的实现,并且需要相应的加密算法和支持代码.这是双重许可与Apache许可证 2.0版(与GPLv2许可也可).网站上指出,mbed ...

  2. STM32 基础系列教程 49 – Jansson

    前言 JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式.它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全 ...

  3. STM32 基础系列教程 48 – CJSON

    前言 JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式.它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全 ...

  4. STM32 基础系列教程 46 – RNG

    前言 随机数发生器(RNG)是一个以连续模拟噪声为基础的随机数发生器,在主机读数时提供一个 32 位的随机数.STM32F407自带RNG ,本节将给大演示STM32F4系列MCU中的RNG的使用.用 ...

  5. STM32 基础系列教程 45 - FSMC_LCD_Touch

    前言 上一节我们完成了用 STM32F4的 FSMC接口来控制 TFTLCD的显示的操作,其实正点原子的探索者F4开发板带的屏幕支持触摸操作,笔者用的是4.3寸的电容触摸屏,本节我们继续实验,来完成基 ...

  6. STM32 基础系列教程 44 - FSMC_LCD

    前言 TFT-LCD 即薄膜晶体管液晶显示器.其英文全称为: Thin Film Transistor-Liquid Crystal Display. TFT-LCD 与无源 TN-LCD. STN- ...

  7. STM32 基础系列教程 43 – SRAM

    前言 STM32F407ZGT6 自带了 192K 字节的 SRAM,对一般应用来说,已经足够了,不过在一些对内存要求高的场合, 比如跑算法或者跑 GUI 等,自带的这些内存就不够用了.比如跑算法或者 ...

  8. STM32 基础系列教程 42 - SDMMC+Fatfs

    前言 本节我们将基于42讲 "STM32 基础系列教程 41 - SDMMC" 的基础来实现基于SD卡文件系统的文件操作. 示例详解 基于硬件平台: 正点源子的stm32f4 探索 ...

  9. STM32 基础系列教程 41 – SDMMC

    前言 SDIO(Secure Digital Input and Output) 安全数字输入输出接口,它支持多种类型的MMC卡,如SD卡,SDIO卡,MMC卡等.STM32 的SD/SDIO MMC ...

最新文章

  1. 品尝阿里云容器服务:5个2核4G节点使用情况记载
  2. 加载vue文件步骤_vue中.vue文件解析步骤详解
  3. Cpp 对象模型探索 / 带有虚继承类的构造函数的调用顺序
  4. 制作html5谭木记页面,北斗区域地理配套练习答案
  5. .NET 云原生架构师训练营(模块二 基础巩固 REST RESTful)--学习笔记
  6. linux下安装jdk_mysql_tomcat_redis
  7. 哈佛第二、哥大第三,第一还是它!2020USNews美国大学排名发布!
  8. 封装的ADO.NET对数据库操作经典类
  9. 老生常谈之CSS的垂直居中
  10. mysql数据库无法显示中文_mysql数据库不能显示中文是怎么回事呢?
  11. 《程序是怎样跑起来的》第六章有感
  12. GIT 操作中 Reinitialized existing Git repository in.......解决方法?
  13. 【Magick++】配置开发环境
  14. 数据分析全国薪酬分布状况
  15. PE文件格式偏移参考
  16. office 2003也能编辑.docx文档
  17. Linux 服务器上搭建SVN服务端
  18. echarts 鼠标经过时改变折线拐点的小圆圈样式
  19. 大数据架构师之路-性能评估
  20. 重装服务器显示bootmgr缺失怎么办,修复“BOOTMGR缺失”的4种方法

热门文章

  1. 201421440008网络攻防实验三
  2. soj1209- 最短的距离(精度问题)
  3. [恢]hdu 1860
  4. vim显示行号、语法高亮、自动缩进的设置
  5. UA MATH567 高维统计I 概率不等式12 McDiarmid不等式
  6. UA SIE545 优化理论基础1 凸分析1 线性流形与超平面
  7. TSQL编写存储过程计算1!+2!+3!+…+N!
  8. 百度地图API公交检索示例 - 标绘结果路线、返回结果集
  9. 离散余弦变换和C语言实现-win32版本
  10. Win32 API、VC++、C# 文件操作函数的初步比较