zoukankan      html  css  js  c++  java
  • sha-hmac

    MAC----message authentication code,保证数据完整性的一个技术。

    HMAC类似于标准的sha运算,只是对于生成的mac增加了基于key的密钥保护

      生成的mac值,随着sender的payload一起发送给receiveder。

      receiveder,拿到mac先进行数据完整性的校验-----重新计算payload,得到自己的mac,与传输过来的mac进行比较。

    HMAC对应的nist标准为FIPS 198-1,其中只是规定了hmac的算法流程,mac计算engine,可以使用nist中推荐的任何hash 算法

    HMAC需要的输入信息;

      1) hash engine的block size的大小(以byte为单位),B

      2) inner pad;byte---"0x36",重复B次;

       outer pad;byte---"0x5c",重复B次;

      3) 输入的key,长度任意,需要经过定义的padding,转变为K0;

     

    流程:

      1) padding key,目的是将输入的任意长度的key,转换为block_size的大小。

        如果输入的key的长度小于等于block size的大小,直接append “0”;

        如果输入的key的长度大于block size的大小,先进行hash engine计算,之后append “0”,组成block size大小

      2) 计算两次hash,输出最终的mac值,

        hash((K0+opad) || hash((K0+ipad) || text ))

      

  • 相关阅读:
    D2. Remove the Substring (hard version)(思维 )
    暑假集训
    AcWing:167. 木棒(dfs + 剪枝)
    AcWing:109. 天才ACM(倍增 + 归并排序)
    AcWing:99. 激光炸弹(前缀和)
    B. Interesting Array(线段树)
    Best Reward HDU
    G. Swapping Places
    How many HDU
    GSS4&&花仔游历各国
  • 原文地址:https://www.cnblogs.com/-9-8/p/9645034.html
Copyright © 2011-2022 走看看