本文整理匯總了Golang中github.com/cloudfoundry/gorouter/common/secure.Crypto.Encrypt方法的典型用法代碼示例。如果您正苦於以下問題:Golang Crypto.Encrypt方法的具體用法?Golang Crypto.Encrypt怎麽用?Golang Crypto.Encrypt使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/cloudfoundry/gorouter/common/secure.Crypto
的用法示例。
在下文中一共展示了Crypto.Encrypt方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: BuildSignatureAndMetadata
func BuildSignatureAndMetadata(crypto secure.Crypto, signature *Signature) (string, string, error) {
signatureJson, err := json.Marshal(&signature)
if err != nil {
return "", "", err
}
signatureJsonEncrypted, nonce, err := crypto.Encrypt(signatureJson)
if err != nil {
return "", "", err
}
metadata := Metadata{
Nonce: nonce,
}
metadataJson, err := json.Marshal(&metadata)
if err != nil {
return "", "", err
}
metadataHeader := base64.URLEncoding.EncodeToString(metadataJson)
signatureHeader := base64.URLEncoding.EncodeToString(signatureJsonEncrypted)
return signatureHeader, metadataHeader, nil
}
示例2:
k := secure.NewPbkdf2([]byte("this-is-a-pretty-long-secret"), 16)
Expect(k).To(HaveLen(16))
})
})
})
})
Describe("Encrypt", func() {
var (
plainText = []byte("this is a secret message!")
)
Context("when the key is valid", func() {
It("encrypts the plain text into a cypher text and returns a nonce", func() {
cipherText, nonce, err := aesGcm.Encrypt(plainText)
Expect(err).ToNot(HaveOccurred())
Expect(cipherText).ToNot(Equal(plainText))
Expect(nonce).To(HaveLen(12))
})
It("returns a different nonce for the same plain text", func() {
cipherText, nonce, err := aesGcm.Encrypt(plainText)
Expect(err).ToNot(HaveOccurred())
Expect(cipherText).ToNot(Equal(plainText))
Expect(nonce).To(HaveLen(12))
cipherText2, nonce2, err := aesGcm.Encrypt(plainText)
Expect(err).ToNot(HaveOccurred())
Expect(cipherText).ToNot(Equal(cipherText2))
Expect(nonce).ToNot(Equal(nonce2))