-1

我正在尝试使用带有给定公钥的快速钠来加密值。但是,加密值与服务器端生成的值不同。我不确定这段编码是否正确。这些步骤类似于它在 java 中的完成方式。

假设公钥是 base64 字符串格式。

爪哇:

String pubKey = "w6mjd11n9w9ncKfcuR888Ygi02ou+46ocIajlcUEmQ="; 
String secret = "hithere"
byte[] pubKeyBytes = Base64.decode(pubKey,0);
SealedBox sealedDeal = new SealedBox(pubKeyBytes);
byte[] c = sealedDeal.encrypt(secret.getBytes());
String ciphertext = Base64.encodeToString(c, 0);  

迅速:

let pubKey = "w6mjd11n9w9ncKfcuR888Ygi02ou+46ocIajlcUEmQ="
let dataDecoded:NSData = NSData(base64Encoded: pubKey, options: NSData.Base64DecodingOptions(rawValue: 0))!
let secret = "hithere".toData()!
let c : Data = sodium.box.seal(message: secret, recipientPublicKey: dataDecoded as Box.PublicKey)!
let ciphertext = c.base64EncodedString(options: .init(rawValue: 0))

请告诉我快速等效编码有什么问题。非常感谢。

4

2 回答 2

0

sodium.box.sealnonce每次加密消息时都会在内部生成新消息,@Max 是对的,这是正常行为

您可以使用Detached mode给相同的随机数,但这是一个非常糟糕的主意

在您使用的示例中,Anonymous Encryption我建议您查看Authenticated Encryption

于 2018-04-03T09:55:25.847 回答
0

加密的值应该是不同的,因此由等效明文产生的密文是不可区分的(请参阅Ciphertext indistinguishability)。

于 2017-05-05T21:29:53.910 回答