Blake算法的流程

2023-10-11 01:49
文章标签 算法 流程 blake

本文主要是介绍Blake算法的流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于Blake算法的网上介绍已经有一部分了,但是关于Blake的流程层面的介绍还是不多的,所以这篇文章的主要目的是介绍Blake的流程,之后会分享代码出来。
声明!本文是为了帮助新手理解Blake算法的,本文不包含代码,需要代码的请关注我,过几天就发出来(其实网上其他博主的代码已经写的挺好的了呢)

前言

BLAKE也需要两个主要的计算过程:预处理过程、和 轮循环计算。
和SHA不同的是,BLAKE不需要对变量进行初始化;
轮循环计算过程,需要把 计数器值、盐值、常量输入消息加入轮循环计算中,按照压缩计算法进行计算,每一轮生成的状态变量用于下一轮循环计算,
在这里插入图片描述
BLAKE有四组输入数据和一组常量:
初始哈希值H[8];输入信息块M;盐值S[4];计数器T[2];常量C;

1. 预处理过程

前三步和SHA2的算法一样,只有变量初始化

  1. 信息填充;
  2. 分割消息块;
  3. 变量初始化:⊕表示异或运算
    在这里插入图片描述
    通过公式计算出16个V,
    其中,计数器T的选取原则是:当最后一个消息块不包含输入消息的比特数时,则计数器为0;前面计数器的值为相应消息块中包含原始消息块中比特数的累加。
    比如:输入消息为600bit,填充之后是1024bit,分割成两个512bit的消息块,此时计数器的值为t0=512,t1=600。 如此可以保证即使两组不同长度的输入消息,再经过填充之后的长度相等,仍可以有不同的计数器值。
    盐值S—自定义的,一般选取固定的;
    常量C—自定义的,一般选取固定的;

2. 循环压缩计算

16个变量V,作为14轮循环压缩的输入,每一轮的循环压缩表示为:
在这里插入图片描述

第r轮的第i个G功能函数的计算规则如下:
在这里插入图片描述

其中“+”表示模加运算,“>>>”表示有循环移位,σ是输入的16个消息字或者常量的第几个消息字,可以根据表格进行置换:
在这里插入图片描述

置换规则中r最大是10,后四轮的规则是当前循环数 mod 10 所得,如:第13轮的置换规则是σ13 mod 10=σ3

3. 最后

经过14轮循环压缩得到16个变量,V0—V15,运算之后得到最终哈希值:
在这里插入图片描述

其中:0≤i≤7 , j= i mod 4,h_i^r表示第r轮哈希值的第i个字。

如果觉得本文有用的话,请点个赞啊!
之后会分享出来Blake2和Blake3的相关代码,可以直接烧录到单片机中的那种,记得点赞啊!

这篇关于Blake算法的流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/184646

相关文章

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请