package coscrypto_test import ( "bytes" "crypto/aes" "crypto/cipher" "crypto/rand" "github.com/stretchr/testify/assert" "github.com/tencentyun/cos-go-sdk-v5/crypto" "io/ioutil" math_rand "math/rand" ) type EmptyMasterCipher struct{} func (mc EmptyMasterCipher) Encrypt(b []byte) ([]byte, error) { return b, nil } func (mc EmptyMasterCipher) Decrypt(b []byte) ([]byte, error) { return b, nil } func (mc EmptyMasterCipher) GetWrapAlgorithm() string { return "Test/EmptyWrapAlgo" } func (mc EmptyMasterCipher) GetMatDesc() string { return "Empty Desc" } func (s *CosTestSuite) TestCryptoObjectService_EncryptAndDecrypt() { var masterCipher EmptyMasterCipher builder := coscrypto.CreateAesCtrBuilder(masterCipher) contentCipher, err := builder.ContentCipher() assert.Nil(s.T(), err, "CryptoObject.CreateAesCtrBuilder Failed") dataSize := math_rand.Int63n(1024 * 1024 * 32) originData := make([]byte, dataSize) rand.Read(originData) // 加密 r1 := bytes.NewReader(originData) reader1, err := contentCipher.EncryptContent(r1) assert.Nil(s.T(), err, "CryptoObject.contentCipher.Encrypt Failed") encryptedData, err := ioutil.ReadAll(reader1) assert.Nil(s.T(), err, "CryptoObject.Read Failed") // 解密 r2 := bytes.NewReader(encryptedData) reader2, err := contentCipher.DecryptContent(r2) decryptedData, err := ioutil.ReadAll(reader2) assert.Nil(s.T(), err, "CryptoObject.Read Failed") assert.Equal(s.T(), bytes.Compare(originData, decryptedData), 0, "decryptData != originData") } func (s *CosTestSuite) TestCryptoObjectService_Encrypt() { var masterCipher EmptyMasterCipher builder := coscrypto.CreateAesCtrBuilder(masterCipher) contentCipher, err := builder.ContentCipher() assert.Nil(s.T(), err, "CryptoObject.CreateAesCtrBuilder Failed") dataSize := math_rand.Int63n(1024 * 1024 * 32) originData := make([]byte, dataSize) rand.Read(originData) // 加密 r := bytes.NewReader(originData) reader, err := contentCipher.EncryptContent(r) assert.Nil(s.T(), err, "CryptoObject.contentCipher.Encrypt Failed") encryptedData, err := ioutil.ReadAll(reader) assert.Nil(s.T(), err, "CryptoObject.Read Failed") // 直接解密 cd := contentCipher.GetCipherData() block, err := aes.NewCipher(cd.Key) assert.Nil(s.T(), err, "CryptoObject.NewCipher Failed") decrypter := cipher.NewCTR(block, cd.IV) decryptedData := make([]byte, len(originData)) decrypter.XORKeyStream(decryptedData, encryptedData) assert.Equal(s.T(), bytes.Compare(originData, decryptedData), 0, "decryptData != originData") } func (s *CosTestSuite) TestCryptoObjectService_Decrypt() { var masterCipher EmptyMasterCipher builder := coscrypto.CreateAesCtrBuilder(masterCipher) contentCipher, err := builder.ContentCipher() assert.Nil(s.T(), err, "CryptoObject.CreateAesCtrBuilder Failed") dataSize := math_rand.Int63n(1024 * 1024 * 32) originData := make([]byte, dataSize) rand.Read(originData) // 直接加密 cd := contentCipher.GetCipherData() block, err := aes.NewCipher(cd.Key) assert.Nil(s.T(), err, "CryptoObject.NewCipher Failed") encrypter := cipher.NewCTR(block, cd.IV) encryptedData := make([]byte, len(originData)) encrypter.XORKeyStream(encryptedData, originData) // 解密 r := bytes.NewReader(encryptedData) reader, err := contentCipher.DecryptContent(r) assert.Nil(s.T(), err, "CryptoObject.contentCipher.Encrypt Failed") decryptedData, err := ioutil.ReadAll(reader) assert.Nil(s.T(), err, "CryptoObject.Read Failed") assert.Equal(s.T(), bytes.Compare(originData, decryptedData), 0, "decryptData != originData") }