STM32 基础系列教程 47 - MD5
前言
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广泛应用于一致性验证同,数字签名,安全访问认证等用途,
- 关于CUBEMX工具及KEIL工具的操作将不再细讲,如果还有不熟悉的可以查看之前的教程文档。下面直接介绍工程配置:
- 系统时钟树
- 串口配置(用于程序调试)
- RCC配置
- SYS配置
- 引脚配置,用到引脚极少
- 堆栈配置(也可保持默认):
- 工程代码
- 将事先准备好的MD5.c 文件加入工程,并将MD5.h文件放到工程INC文件夹下,这些文件可以在Lwip协议栈中提取,当然百度也能百度得到:
- 在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相关推荐
- STM32 基础系列教程 50 – MbedTls
前言 mbed TLS(以前称为PolarSSL)是TLS和SSL协议的实现,并且需要相应的加密算法和支持代码.这是双重许可与Apache许可证 2.0版(与GPLv2许可也可).网站上指出,mbed ...
- STM32 基础系列教程 49 – Jansson
前言 JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式.它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全 ...
- STM32 基础系列教程 48 – CJSON
前言 JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式.它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全 ...
- STM32 基础系列教程 46 – RNG
前言 随机数发生器(RNG)是一个以连续模拟噪声为基础的随机数发生器,在主机读数时提供一个 32 位的随机数.STM32F407自带RNG ,本节将给大演示STM32F4系列MCU中的RNG的使用.用 ...
- STM32 基础系列教程 45 - FSMC_LCD_Touch
前言 上一节我们完成了用 STM32F4的 FSMC接口来控制 TFTLCD的显示的操作,其实正点原子的探索者F4开发板带的屏幕支持触摸操作,笔者用的是4.3寸的电容触摸屏,本节我们继续实验,来完成基 ...
- STM32 基础系列教程 44 - FSMC_LCD
前言 TFT-LCD 即薄膜晶体管液晶显示器.其英文全称为: Thin Film Transistor-Liquid Crystal Display. TFT-LCD 与无源 TN-LCD. STN- ...
- STM32 基础系列教程 43 – SRAM
前言 STM32F407ZGT6 自带了 192K 字节的 SRAM,对一般应用来说,已经足够了,不过在一些对内存要求高的场合, 比如跑算法或者跑 GUI 等,自带的这些内存就不够用了.比如跑算法或者 ...
- STM32 基础系列教程 42 - SDMMC+Fatfs
前言 本节我们将基于42讲 "STM32 基础系列教程 41 - SDMMC" 的基础来实现基于SD卡文件系统的文件操作. 示例详解 基于硬件平台: 正点源子的stm32f4 探索 ...
- STM32 基础系列教程 41 – SDMMC
前言 SDIO(Secure Digital Input and Output) 安全数字输入输出接口,它支持多种类型的MMC卡,如SD卡,SDIO卡,MMC卡等.STM32 的SD/SDIO MMC ...
最新文章
- 品尝阿里云容器服务:5个2核4G节点使用情况记载
- 加载vue文件步骤_vue中.vue文件解析步骤详解
- Cpp 对象模型探索 / 带有虚继承类的构造函数的调用顺序
- 制作html5谭木记页面,北斗区域地理配套练习答案
- .NET 云原生架构师训练营(模块二 基础巩固 REST RESTful)--学习笔记
- linux下安装jdk_mysql_tomcat_redis
- 哈佛第二、哥大第三,第一还是它!2020USNews美国大学排名发布!
- 封装的ADO.NET对数据库操作经典类
- 老生常谈之CSS的垂直居中
- mysql数据库无法显示中文_mysql数据库不能显示中文是怎么回事呢?
- 《程序是怎样跑起来的》第六章有感
- GIT 操作中 Reinitialized existing Git repository in.......解决方法?
- 【Magick++】配置开发环境
- 数据分析全国薪酬分布状况
- PE文件格式偏移参考
- office 2003也能编辑.docx文档
- Linux 服务器上搭建SVN服务端
- echarts 鼠标经过时改变折线拐点的小圆圈样式
- 大数据架构师之路-性能评估
- 重装服务器显示bootmgr缺失怎么办,修复“BOOTMGR缺失”的4种方法
热门文章
- 201421440008网络攻防实验三
- soj1209- 最短的距离(精度问题)
- [恢]hdu 1860
- vim显示行号、语法高亮、自动缩进的设置
- UA MATH567 高维统计I 概率不等式12 McDiarmid不等式
- UA SIE545 优化理论基础1 凸分析1 线性流形与超平面
- TSQL编写存储过程计算1!+2!+3!+…+N!
- 百度地图API公交检索示例 - 标绘结果路线、返回结果集
- 离散余弦变换和C语言实现-win32版本
- Win32 API、VC++、C# 文件操作函数的初步比较