EncryptionConfig
配置内置加密模式和密钥。
public class EncryptionConfig { public EncryptionConfig() { encryptionMode = ENCRYPTION_MODE.MODE_END; encryptionKey = ""; encryptionKdfSalt = new byte[32]; } public EncryptionConfig(ENCRYPTION_MODE encryptionMode, string encryptionKey, byte[] encryptionKdfSalt) { this.encryptionMode = encryptionMode; this.encryptionKey = encryptionKey; this.encryptionKdfSalt = encryptionKdfSalt; } public ENCRYPTION_MODE encryptionMode { set; get; } public string encryptionKey { set; get; } private byte[] encryptionKdfSalt32 = new byte[32]; public byte[] encryptionKdfSalt { set { Buffer.BlockCopy(value, 0, encryptionKdfSalt32, 0, 32); } get { return encryptionKdfSalt32; } } }
属性
- encryptionMode
-
内置加密模式。详见 ENCRYPTION_MODE。建议使用
AES_128_GCM2
或AES_256_GCM2
加密模式。这两种模式支持使用盐,安全性更高。 - encryptionKey
-
内置加密密钥,字符串类型,长度无限制。建议使用 32 字节的密钥。
注意: 如果未指定该参数或将该参数设置为NULL
,则无法启用内置加密,且 SDK 会返回错误码-2
。 - encryptionKdfSalt
-
盐,长度为 32 字节。建议你在服务端使用 OpenSSL 生成盐。
注意: 只有在AES_128_GCM2
或AES_256_GCM2
加密模式下,该参数才生效。此时,需确保填入该参数的值不全为0
。