Luk*_*ang 5 signature protocol-buffers
有没有通用的方法来签署 protobuf 消息?我可以想象的是在消息中添加数据字段和签名字段,并使用 SerializeToArray(在 cpp 中)或 ToByteArray(在 c# 中)获取原始字节,然后使用 md5 或 sha256 .. 等来计算哈希值,然后将哈希值分配给字段“sign”。但是我不知道不同语言之间或 proto2 和 proto3 中的原始字节是否有任何不同?
只要您的散列算法足够强大,您讨论的签名方法就可以用于完整性验证目的。如果它是为了比完整性校验和更强的东西,您可能应该使用真正的加密哈希(带有公钥+私钥),因为任何人都可以以其他方式签署自己的任意有效负载,从而破坏了这一点。
您还看到讨论决定论。protobuf 中的原始字节并不完全确定。在 protobuf 中表示相同有效负载的有效方式有多种,包括:
| 归档时间: |
|
| 查看次数: |
2128 次 |
| 最近记录: |