crypto.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package myth
  2. import (
  3. "bytes"
  4. "crypto/aes"
  5. "crypto/cipher"
  6. )
  7. var (
  8. aesKey string
  9. aesIV string
  10. )
  11. // AesCrypto define
  12. type AesCrypto struct {
  13. Key []byte
  14. IV []byte
  15. }
  16. // SetAesCryptoKey set key,
  17. // key/iv length:16, 24, 32 bytes to AES-128, AES-192, AES-256
  18. func SetAesCryptoKey(password, iv string) {
  19. aesKey = password
  20. }
  21. // GetAesCryptoKey get current key
  22. func GetAesCryptoKey() string {
  23. return aesKey
  24. }
  25. // NewAesCrypto new AesCrypto
  26. func NewAesCrypto() *AesCrypto {
  27. return &AesCrypto{Key: []byte(aesKey), IV: []byte(aesIV)}
  28. }
  29. // SetKey set key
  30. func (a *AesCrypto) SetKey(key, iv string) {
  31. a.Key = []byte(key)
  32. a.IV = []byte(iv)
  33. }
  34. // Encrypt encrypt data
  35. func (a *AesCrypto) Encrypt(data []byte) ([]byte, error) {
  36. block, err := aes.NewCipher(a.Key)
  37. if err != nil {
  38. return nil, err
  39. }
  40. blockSize := block.BlockSize()
  41. data = pkcs5Padding(data, blockSize)
  42. blockMode := cipher.NewCBCEncrypter(block, a.IV[:blockSize])
  43. crypted := make([]byte, len(data))
  44. blockMode.CryptBlocks(crypted, data)
  45. return crypted, nil
  46. }
  47. // Decrypt decrypt data
  48. func (a *AesCrypto) Decrypt(crypted []byte) ([]byte, error) {
  49. block, err := aes.NewCipher(a.Key)
  50. if err != nil {
  51. return nil, err
  52. }
  53. blockSize := block.BlockSize()
  54. blockMode := cipher.NewCBCDecrypter(block, a.IV[:blockSize])
  55. origData := make([]byte, len(crypted))
  56. blockMode.CryptBlocks(origData, crypted)
  57. origData = pkcs5UnPadding(origData)
  58. return origData, nil
  59. }
  60. func pkcs5Padding(cipherText []byte, blockSize int) []byte {
  61. padding := blockSize - len(cipherText)%blockSize
  62. padtext := bytes.Repeat([]byte{byte(padding)}, padding)
  63. return append(cipherText, padtext...)
  64. }
  65. func pkcs5UnPadding(data []byte) []byte {
  66. length := len(data)
  67. unpadding := int(data[length-1])
  68. if unpadding >= length {
  69. return []byte(``)
  70. }
  71. return data[:(length - unpadding)]
  72. }