123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- package conn
- import (
- "github.com/cnlh/nps/lib/crypt"
- "github.com/cnlh/nps/lib/pool"
- "github.com/cnlh/nps/lib/rate"
- "io"
- )
- type CryptConn struct {
- conn io.ReadWriteCloser
- crypt bool
- rate *rate.Rate
- }
- func NewCryptConn(conn io.ReadWriteCloser, crypt bool, rate *rate.Rate) *CryptConn {
- c := new(CryptConn)
- c.conn = conn
- c.crypt = crypt
- c.rate = rate
- return c
- }
- //加密写
- func (s *CryptConn) Write(b []byte) (n int, err error) {
- n = len(b)
- if s.crypt {
- if b, err = crypt.AesEncrypt(b, []byte(cryptKey)); err != nil {
- return
- }
- }
- if b, err = GetLenBytes(b); err != nil {
- return
- }
- _, err = s.conn.Write(b)
- if s.rate != nil {
- s.rate.Get(int64(n))
- }
- return
- }
- //解密读
- func (s *CryptConn) Read(b []byte) (n int, err error) {
- var lens int
- var buf []byte
- var rb []byte
- if lens, err = GetLen(s.conn); err != nil || lens > len(b) || lens < 0 {
- return
- }
- buf = pool.BufPool.Get().([]byte)
- defer pool.BufPool.Put(buf)
- if n, err = io.ReadFull(s.conn, buf[:lens]); err != nil {
- return
- }
- if s.crypt {
- if rb, err = crypt.AesDecrypt(buf[:lens], []byte(cryptKey)); err != nil {
- return
- }
- } else {
- rb = buf[:lens]
- }
- copy(b, rb)
- n = len(rb)
- if s.rate != nil {
- s.rate.Get(int64(n))
- }
- return
- }
- func (s *CryptConn) Close() error {
- return s.conn.Close()
- }
|