常见泽1 发表于 2023-6-2 23:39

【STM32H5开发板】第九篇 硬件HASH工程测试

<p>&nbsp;</p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">单向散列算法单向散列算法,又称hash哈希函数,Hash函数(也称杂凑算法)就是把任意长的输入消息串变化成固定长的输出串的一种函数,该过程是不可逆的。Hash函数可用于数字签名、消息的完整性检测、消息起源的认证检测等。较为常用的方法包括MD算法和SHA算法。</span></span></p>

<p >&nbsp;</p>

<p align="left" ><span style="font-family:宋体;"><span style="font-size:16px;">STM32的哈希模块 Hash,支持的哈希算法有:SHA-1, SHA-224, SHA-256等</span></span></p>

<p align="left" ><span style="font-family:宋体;"><span style="font-size:16px;">集成该哈希硬件加速模块的STM32系列</span></span></p>

<p align="left" >&nbsp;</p>

<p > &nbsp;</p>

<p >&nbsp;</p>

<p><span style="font-family:宋体;"><span style="font-size:16px;">SHA(Secure Hash Algorithm)安全散列算法SHA是一个密码散列函数家族,SHA算法主要分为SHA-1、SHA-2、SHA-3 三大类,</span></span></p>

<p><span style="font-family:宋体;"><span style="font-size:16px;">一般使用SHA-2算法,主要有SHA-256、SHA-512、SHA-224、SHA-384四种,对于嵌入式一般选择SHA256,将任意长度的输入压缩成256位,且哈希碰撞的概率近乎为0。</span></span></p>

<p><span style="font-family:宋体;"><span style="font-size:16px;">应用场景:数字签名、数字时间戳、数字证书。</span></span></p>

<p><span style="font-family:宋体;"><span style="font-size:16px;">SHA256一般嵌入式系统签名或者校验复杂版使用SHA256,也就是长度小于2^64字节的任意数据,经过哈希运算得到256比特的消息摘要。</span></span></p>

<p>&nbsp;</p>

<p>&nbsp;</p>

<p><span style="font-family:宋体;"><span style="font-size:16px;">具体HASH算法的原理太复杂了,我也看不下去了,直接看看怎么用吧</span></span></p>

<p>&nbsp;</p>

<p><span style="font-family:宋体;"><span style="font-size:16px;">一通过CUBE生成HASH的基本工程</span></span></p>

<p > &nbsp;</p>

<p >&nbsp;</p>

<p > &nbsp;</p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">SHA可以选择很多类型,比如SHA1等</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">这里选择SHA256</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">其它配置都是选择之前工程的</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">二加密工具测试下 SHA256的结果</span></span></p>

<p > &nbsp;</p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">三下面开始自己加自己的代码</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">加入定义</span></span></p>

<p >&nbsp;</p>

<p > &nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">添加测试代码</span></span></p>

<p ><br />
&nbsp;</p>

<pre>
<code class="language-cpp">if (HAL_HASH_Start_IT(&amp;hhash, (uint8_t*)aInput, strlen((char const*)aInput), aSHA256Digest) != HAL_OK)

  {

    Error_Handler();

  }

  while (HAL_HASH_GetState(&amp;hhash) != HAL_HASH_STATE_READY);



 /* Compare computed digest with expected one */

  if(memcmp(aSHA256Digest, aExpectSHA256Digest, sizeof(aExpectSHA256Digest)/sizeof(aExpectSHA256Digest)) != 0)

  {

    Error_Handler();

  }

  else

  {

    HAL_GPIO_WritePin(GPIOF,GPIO_PIN_4,GPIO_PIN_SET);

  }</code></pre>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">先计算再比较</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">查看现象,灯亮,工作正常。</span></span></p>

<p >&nbsp;</p>

<p >&nbsp;</p>

<p >&nbsp;</p>

<p >&nbsp;</p>

Jacktang 发表于 2023-6-3 10:40

<p>HASH算法的原理确实复杂看不懂,看楼主的应用还是明白多了</p>
页: [1]
查看完整版本: 【STM32H5开发板】第九篇 硬件HASH工程测试