目前,我正在使用以下代码来获取Rust结构和枚举的sha256哈希值。
pub fn sha256<T: Sized + Serialize>(ser: T) -> [u8; 32] {
let str = ron::ser::to_string(&ser).expect("serialization has failed");
let mut hasher = Sha256::new();
hasher.update(str);
let hash = hasher.finalize();
*hash.as_ref()
}
这可行,但远非理想:在许多类型上都有一个
.hash()
方法,但这似乎适用于64位非加密哈希(HashMap等)。我如何以密码方式哈希任意的Rust结构和枚举,以使散列是相同的,而与体系结构/字大小/字节序无关? (我不使用
usize
。)
最佳答案
如果要使用加密哈希来哈希对象,则必须将其转换为字节流,因为这是加密哈希唯一接受的东西。我们通常将其称为序列化。
您可以执行以下操作:
或者,您可以尝试构建自定义的
Hasher
实现,该实现也可以输出SHA-256值。然后,您的结构将需要实现Hash
而不是Serialize
,并且您将以增量方式进行哈希处理。这可能会或可能不会更快。
关于rust - Rust结构/枚举的可复制加密哈希,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62979022/