26 lines
522 B
Go
26 lines
522 B
Go
|
package xorencrypt
|
||
|
|
||
|
import "encoding/base64"
|
||
|
|
||
|
func Decrypt(msg, key string) (string, error) {
|
||
|
deb64, err := base64.StdEncoding.DecodeString(msg)
|
||
|
if err != nil {
|
||
|
return "", err
|
||
|
}
|
||
|
dec := xor(deb64, []byte(key))
|
||
|
return string(dec), nil
|
||
|
}
|
||
|
|
||
|
func Encrypt(msg, key string) string {
|
||
|
enc := xor([]byte(msg), []byte(key))
|
||
|
return base64.StdEncoding.EncodeToString(enc)
|
||
|
}
|
||
|
|
||
|
func xor(msg, key []byte) []byte {
|
||
|
ret := make([]byte, len(msg))
|
||
|
for i := 0; i < len(msg); i++ {
|
||
|
ret[i] = msg[i] ^ key[i%len(key)]
|
||
|
}
|
||
|
return ret
|
||
|
}
|