Documentation ¶
Index ¶
- Variables
- func AddkeyEncrypt(oid asn1.ObjectIdentifier, fn func() KeyEncrypt)
- func Decrypt(data []byte, cert *x509.Certificate, pkey crypto.PrivateKey) ([]byte, error)
- func DecryptUsingPSK(data []byte, key []byte) ([]byte, error)
- func Encrypt(rand io.Reader, content []byte, recipients []*x509.Certificate, opts ...Opts) ([]byte, error)
- func EncryptUsingPSK(rand io.Reader, content []byte, key []byte, cipher Cipher) ([]byte, error)
- type Cipher
- type KeyEncrypt
- type KeyEncryptWithRsa
- type KeyEncryptWithSM2
- type Opts
Constants ¶
This section is empty.
Variables ¶
View Source
var ( AddCipher = pbes2.AddCipher GetCipher = pbes2.GetCipher // 帮助函数 GetCipherFromName = pbes2.GetCipherFromName CheckCipherFromName = pbes2.CheckCipherFromName )
View Source
var ( DESCBC = pbes2.DESCBC DESEDE3CBC = pbes2.DESEDE3CBC RC2CBC = pbes2.RC2CBC RC2_40CBC = pbes2.RC2_40CBC RC2_64CBC = pbes2.RC2_64CBC RC2_128CBC = pbes2.RC2_128CBC RC5CBC = pbes2.RC5CBC RC5_128CBC = pbes2.RC5_128CBC RC5_192CBC = pbes2.RC5_192CBC RC5_256CBC = pbes2.RC5_256CBC AES128ECB = pbes2.AES128ECB AES128CBC = pbes2.AES128CBC AES128OFB = pbes2.AES128OFB AES128CFB = pbes2.AES128CFB AES128GCM = pbes2.AES128GCM AES128CCM = pbes2.AES128CCM AES192ECB = pbes2.AES192ECB AES192CBC = pbes2.AES192CBC AES192OFB = pbes2.AES192OFB AES192CFB = pbes2.AES192CFB AES192GCM = pbes2.AES192GCM AES192CCM = pbes2.AES192CCM AES256ECB = pbes2.AES256ECB AES256CBC = pbes2.AES256CBC AES256OFB = pbes2.AES256OFB AES256CFB = pbes2.AES256CFB AES256GCM = pbes2.AES256GCM AES256CCM = pbes2.AES256CCM SM4ECB = pbes2.SM4ECB SM4CBC = pbes2.SM4CBC SM4OFB = pbes2.SM4OFB SM4CFB = pbes2.SM4CFB SM4CFB1 = pbes2.SM4CFB1 SM4CFB8 = pbes2.SM4CFB8 SM4GCM = pbes2.SM4GCM SM4CCM = pbes2.SM4CCM GostCipher = pbes2.GostCipher )
加密方式
View Source
var DefaultOpts = Opts{ Cipher: AES256CBC, KeyEncrypt: KeyEncryptRSA, }
默认配置
View Source
var ErrPSKNotProvided = errors.New("pkcs7: cannot encrypt content: PSK not provided")
View Source
var ErrUnsupportedEncryptionAlgorithm = errors.New("pkcs7: cannot encrypt content: only DES-CBC, AES-CBC, and AES-GCM supported")
View Source
var KeyEncryptRSA = KeyEncryptWithRsa{ // contains filtered or unexported fields }
KeyEncryptRSA
View Source
var KeyEncryptRSAESOAEP = KeyEncryptWithRsa{ // contains filtered or unexported fields }
KeyEncryptRSAESOAEP
View Source
var KeyEncryptRSASHA1 = KeyEncryptWithRsa{ // contains filtered or unexported fields }
KeyEncryptRSASHA1
View Source
var KeyEncryptRSASHA256 = KeyEncryptWithRsa{ // contains filtered or unexported fields }
KeyEncryptRSASHA256
View Source
var KeyEncryptRSASHA384 = KeyEncryptWithRsa{ // contains filtered or unexported fields }
KeyEncryptRSASHA384
View Source
var KeyEncryptRSASHA512 = KeyEncryptWithRsa{ // contains filtered or unexported fields }
KeyEncryptRSASHA512
View Source
var KeyEncryptSM2 = KeyEncryptWithSM2{ // contains filtered or unexported fields }
KeyEncryptSM2
Functions ¶
func AddkeyEncrypt ¶
func AddkeyEncrypt(oid asn1.ObjectIdentifier, fn func() KeyEncrypt)
添加 key 加密方式
func Decrypt ¶
func Decrypt(data []byte, cert *x509.Certificate, pkey crypto.PrivateKey) ([]byte, error)
解析
func DecryptUsingPSK ¶
DecryptUsingPSK decrypts encrypted data using caller provided pre-shared secret
Types ¶
type KeyEncrypt ¶
type KeyEncrypt interface { // oid OID() asn1.ObjectIdentifier // 加密, 返回: [加密后数据, error] Encrypt(plaintext []byte, pkey crypto.PublicKey) ([]byte, error) // 解密 Decrypt(ciphertext []byte, pkey crypto.PrivateKey) ([]byte, error) }
非对称加密
type KeyEncryptWithRsa ¶
type KeyEncryptWithRsa struct {
// contains filtered or unexported fields
}
key 用 rsa 加密
func (KeyEncryptWithRsa) Decrypt ¶
func (this KeyEncryptWithRsa) Decrypt(ciphertext []byte, pkey crypto.PrivateKey) ([]byte, error)
解密
type KeyEncryptWithSM2 ¶
type KeyEncryptWithSM2 struct {
// contains filtered or unexported fields
}
key 用 sm2 加密
func (KeyEncryptWithSM2) Decrypt ¶
func (this KeyEncryptWithSM2) Decrypt(ciphertext []byte, pkey crypto.PrivateKey) ([]byte, error)
解密
Click to show internal directories.
Click to hide internal directories.