SHA-256算法流程分析与演示——github工程完善

https://github.com/in3rsha/sha256-animation

上面是原作者github代码,写的是相当吊,笔者将其代码进行进行了复现和SHA-256算法的学习如下文

https://blog.csdn.net/daviddou2022/article/details/149207087

除此之外,笔者在上一篇文章中也提到原作者的工程有可完善之处,主要是对于命令行输入参数这一块,因此笔者对于sha-256的功能进行完善,完整的工程如下:

https://github.com/daviddou2023/sha256-explanation

1、message.rb

不需要修改原代码

2、padding.rb

将红框标出的三行原代码改成下面的,原代码最终的message赋值是二进制,也就是说只有当命令行参数输入为二进制才能执行,但是考虑到message一般为字符串,所以做此修改。

复制代码
# Use command line argument if provided, else default to "abc"
  $input = ARGV[0] || "abc"  
  $message = $input.unpack("B*")[0] # Convert to binary string

3、blocks.rd

同padding.rd修改方式

复制代码
# Use command line argument if provided, else default to "abc"
  $input = ARGV[0] || "abc"  
  $message = $input.unpack("B*")[0] # Convert to binary string

4、schedule.rd

红框的代码换为下面的代码

5、expansion.rb

还是将input的部分同上修改,还需要注意的是将原代码中的block赋值部分删掉。

复制代码
# Use command line argument if provided, else default to "abc"
  $input = ARGV[0] || "abc"  
  $message = $input.unpack("B*")[0] # Convert to binary string

6、initial.rb

不涉及到输入参数,不需要修改,直接ruby initial.rb

7、t1.rb t2.rb

同理代码替换

复制代码
# Use command line argument if provided, else default to "abc"
  $input = ARGV[0] || "abc"  
  $message = $input.unpack("B*")[0] # Convert to binary string

8、compression.rb

复制代码
# Use command line argument if provided, else default to "abc"
  $input = ARGV[0] || "abc"  
  $message = $input.unpack("B*")[0] # Convert to binary string

9、final.rb

复制代码
# Use command line argument if provided, else default to "abc"
  $input = ARGV[0] || "abc"  
  $message = $input.unpack("B*")[0] # Convert to binary string

10、sha-256.rb

不需要修改原代码

相关推荐
CodeByV1 天前
【算法题】哈希
算法·哈希算法
专注于大数据技术栈1 天前
java学习--HashSet
java·学习·哈希算法
a努力。1 天前
字节跳动Java面试被问:一致性哈希的虚拟节点和数据迁移
java·开发语言·分布式·算法·缓存·面试·哈希算法
源代码•宸1 天前
Golang原理剖析(map)
经验分享·后端·算法·golang·哈希算法·散列表·map
爱敲代码的TOM2 天前
详解一致性哈希算法
算法·哈希算法
番茄灭世神2 天前
密码学入门基础
网络安全·区块链·密码学·哈希算法
小北方城市网2 天前
数据库性能优化实战指南:从索引到架构,根治性能瓶颈
数据结构·数据库·人工智能·性能优化·架构·哈希算法·散列表
南行*2 天前
逆向中的Hash类算法
算法·网络安全·哈希算法
君义_noip3 天前
【模板:字符串哈希】信息学奥赛一本通 1455:【例题1】Oulipo
算法·哈希算法·信息学奥赛·csp-s
Tancenter3 天前
区块链关键技术
区块链·哈希算法·数字签名