代码拉取完成,页面将自动刷新
package dongle
import (
"crypto/rc4"
"fmt"
)
type Rc4Error struct {
}
func NewRc4Error() Rc4Error {
return Rc4Error{}
}
func (e Rc4Error) KeyError() error {
return fmt.Errorf("rc4: invalid key, the key at least 1 byte and at most 256 bytes")
}
// ByRc4 encrypts by rc4.
func (e Encrypter) ByRc4(key []byte) Encrypter {
if len(e.src) == 0 || e.Error != nil {
return e
}
rc4Error := Rc4Error{}
cipher, err := rc4.NewCipher(key)
if err != nil {
e.Error = rc4Error.KeyError()
return e
}
dst := make([]byte, len(e.src))
cipher.XORKeyStream(dst, e.src)
e.dst = dst
return e
}
// ByRc4 decrypts by rc4.
func (d Decrypter) ByRc4(key []byte) Decrypter {
if len(d.src) == 0 || d.Error != nil {
return d
}
rc4Error := Rc4Error{}
cipher, err := rc4.NewCipher(key)
if err != nil {
d.Error = rc4Error.KeyError()
return d
}
dst := make([]byte, len(d.src))
cipher.XORKeyStream(dst, d.src)
d.dst = dst
return d
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。