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

不需要修改原代码

相关推荐
承渊政道1 天前
【动态规划算法】(子数组系列问题建模与解题思路精讲)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
AI人工智能+电脑小能手2 天前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
逻辑驱动的ken2 天前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
AI人工智能+电脑小能手2 天前
【大白话说Java面试题】【Java基础篇】第23题:ConcurrentHashMap的底层原理是什么
java·开发语言·算法·哈希算法·散列表·hash
ん贤3 天前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
AI人工智能+电脑小能手3 天前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
liuyao_xianhui3 天前
进程概念与进程状态_Linux
linux·运维·服务器·数据结构·c++·哈希算法·宽度优先
AI人工智能+电脑小能手3 天前
【大白话说Java面试题】【Java基础篇】第21题:HashMap和Hashtable的区别是什么
java·开发语言·面试·哈希算法·散列表·hash table
凯瑟琳.奥古斯特3 天前
图论核心考点精讲
开发语言·数据结构·算法·排序算法·哈希算法
沉默-_-4 天前
备战蓝桥杯-哈希
c++·学习·算法·蓝桥杯·哈希算法