本文整理汇总了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))