gpt4 book ai didi

c# - 是否可以在 C# 中处理单个位?尝试实现 SHA256 生成器

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:47:18 27 4
gpt4 key购买 nike

只是为了好玩,我正在阅读 pseudo-code on Wikipedia它表示在预处理时将位“1”附加到消息,然后将足够的“0”位附加到生成的消息长度模数 512 为 448。然后将消息的长度附加为 64 位大-endian 整数。

好的。我不确定如何只附加一个“1”位,但我认为可以只附加 128(1000 0000),但如果没有所有结果的消息长度模数 512 已经是 448,那将行不通那些额外的0。在这种情况下,我不确定如何仅附加一个 1,因为我至少需要处理字节。在 C# 中可以吗?

另外,是否有内置的方法来附加大端整数,因为我相信我的系统默认是小端。

最佳答案

它的定义方式是,如果消息是偶数个字节,则只需要处理字节。如果消息长度(mod 64)为 56,则追加 0b10000000 的一个字节,后跟 63 个 0 字节,然后是长度。否则追加1个字节0b10000000,后面是0到62个0字节,最后是长度。

关于c# - 是否可以在 C# 中处理单个位?尝试实现 SHA256 生成器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16006588/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com