1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- package crypto
- import (
- "crypto/aes"
- "crypto/cipher"
- "crypto/rand"
- "crypto/sha1"
- "io"
- "golang.org/x/crypto/pbkdf2"
- )
- const (
- salt = "frp"
- )
- func NewWriter(w io.Writer, key []byte) (*Writer, error) {
- key = pbkdf2.Key(key, []byte(salt), 64, aes.BlockSize, sha1.New)
-
- iv := make([]byte, aes.BlockSize)
- if _, err := io.ReadFull(rand.Reader, iv); err != nil {
- return nil, err
- }
- block, err := aes.NewCipher(key)
- if err != nil {
- return nil, err
- }
- return &Writer{
- w: w,
- enc: &cipher.StreamWriter{
- S: cipher.NewCFBEncrypter(block, iv),
- W: w,
- },
- key: key,
- iv: iv,
- }, nil
- }
- type Writer struct {
- w io.Writer
- enc *cipher.StreamWriter
- key []byte
- iv []byte
- ivSend bool
- err error
- }
- func (w *Writer) Write(p []byte) (nRet int, errRet error) {
- if w.err != nil {
- return 0, w.err
- }
-
- if !w.ivSend {
- w.ivSend = true
- _, errRet = w.w.Write(w.iv)
- if errRet != nil {
- w.err = errRet
- return
- }
- }
- nRet, errRet = w.enc.Write(p)
- if errRet != nil {
- w.err = errRet
- }
- return
- }
|