update
This commit is contained in:
parent
f426b7b2cc
commit
0a7d7dd290
@ -61,38 +61,37 @@ func handlerClient(conn net.Conn, serverAddress string, fakeAddressSNI string) {
|
|||||||
|
|
||||||
p := &PackAppData{Conn: dial.NetConn()}
|
p := &PackAppData{Conn: dial.NetConn()}
|
||||||
|
|
||||||
go io.Copy(conn, p)
|
defer p.Close()
|
||||||
go io.Copy(p, conn)
|
defer conn.Close()
|
||||||
|
exitCh := make(chan int, 1)
|
||||||
|
|
||||||
|
go MyCopy(conn, p, exitCh)
|
||||||
|
go MyCopy(p, conn, exitCh)
|
||||||
|
<-exitCh
|
||||||
}
|
}
|
||||||
|
|
||||||
func MyCopy(src io.ReadWriteCloser, dst io.ReadWriteCloser) {
|
func MyCopy(src io.ReadWriteCloser, dst io.ReadWriteCloser, ch chan int) {
|
||||||
buf := make([]byte, 32*1024)
|
buf := make([]byte, 32*1024)
|
||||||
for {
|
for {
|
||||||
nr, er := src.Read(buf)
|
nr, er := src.Read(buf)
|
||||||
if nr > 0 {
|
if er != nil {
|
||||||
nw, ew := dst.Write(buf[0:nr])
|
if er == io.EOF {
|
||||||
if nw < 0 || nr < nw {
|
break
|
||||||
nw = 0
|
} else {
|
||||||
if ew == nil {
|
fmt.Printf("Read err: %v\n", er)
|
||||||
fmt.Printf("err1:\n")
|
break
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
nw, ew := dst.Write(buf[0:nr])
|
||||||
if ew != nil {
|
if ew != nil {
|
||||||
fmt.Printf("err2:%v\n", ew)
|
fmt.Printf("Write error:%v\n", ew)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
if nr != nw {
|
if nr != nw {
|
||||||
fmt.Printf("nr != nw \n")
|
fmt.Printf("Write less then buffered \n")
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if er != nil {
|
|
||||||
if er != io.EOF {
|
|
||||||
fmt.Printf("err3:%v\n", er)
|
|
||||||
} else {
|
|
||||||
fmt.Println("EOF")
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
ch <- 1
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,14 @@ func TestName(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestName2(t *testing.T) {
|
func TestName2(t *testing.T) {
|
||||||
v := "12345678"
|
b := []byte("ABC")
|
||||||
fmt.Println(v[2:2])
|
encrypt, err := AesEncrypt(b, []byte("1234567812345678"))
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
}
|
||||||
|
decrypt, err := AesDecrypt(encrypt, []byte("1234567812345678"))
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
}
|
||||||
|
fmt.Println(string(decrypt))
|
||||||
}
|
}
|
||||||
|
@ -3,12 +3,14 @@ package shadow
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
"net"
|
"net"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
AppDataHeader = []byte("GGGGGGGG")
|
AppDataHeader = []byte{0x17, 0x3, 0x3}
|
||||||
HeaderLength = len(AppDataHeader)
|
HeaderLength = len(AppDataHeader)
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -17,25 +19,48 @@ type PackAppData struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m PackAppData) Read(p []byte) (n int, err error) {
|
func (m PackAppData) Read(p []byte) (n int, err error) {
|
||||||
buf := make([]byte, 32*1024)
|
|
||||||
read, err := m.Conn.Read(buf[0 : HeaderLength+2])
|
buf := make([]byte, 32*1024+HeaderLength+2)
|
||||||
|
|
||||||
|
headRead, err := io.ReadAtLeast(m.Conn, buf[0:HeaderLength+2], HeaderLength+2)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("Read header error: %v\n", err)
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
if headRead < HeaderLength+2 {
|
||||||
|
return 0, errors.New("Read header failed")
|
||||||
|
}
|
||||||
if bytes.Equal(buf[0:HeaderLength], AppDataHeader) {
|
if bytes.Equal(buf[0:HeaderLength], AppDataHeader) {
|
||||||
u := int(binary.BigEndian.Uint16(buf[HeaderLength : HeaderLength+2]))
|
payLoadLength := int(binary.BigEndian.Uint16(buf[HeaderLength : HeaderLength+2]))
|
||||||
r, err := m.Conn.Read(buf[HeaderLength+2 : u+HeaderLength+2])
|
sum := 0
|
||||||
copy(p, buf[HeaderLength+2:r+HeaderLength+2])
|
for sum < payLoadLength {
|
||||||
return r, err
|
r, e := m.Conn.Read(buf[HeaderLength+2+sum : HeaderLength+2+payLoadLength])
|
||||||
|
if e != nil {
|
||||||
|
if e == io.EOF {
|
||||||
|
break
|
||||||
|
} else {
|
||||||
|
return 0, e
|
||||||
|
}
|
||||||
|
}
|
||||||
|
copy(p[sum:], buf[HeaderLength+2+sum:HeaderLength+2+sum+r])
|
||||||
|
sum += r
|
||||||
|
}
|
||||||
|
return sum, err
|
||||||
} else {
|
} else {
|
||||||
fmt.Println("Header is not present")
|
fmt.Printf("Invalid header")
|
||||||
return read, err
|
return 0, errors.New("invalid header")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m PackAppData) Write(p []byte) (n int, err error) {
|
func (m PackAppData) Write(p []byte) (n int, err error) {
|
||||||
t := make([]byte, len(p)+HeaderLength+2)
|
lenNum := make([]byte, 2)
|
||||||
copy(t[0:], AppDataHeader)
|
binary.BigEndian.PutUint16(lenNum, uint16(len(p)))
|
||||||
binary.BigEndian.PutUint16(t[HeaderLength:], uint16(len(p)))
|
|
||||||
copy(t[HeaderLength+2:], p)
|
packetBuf := bytes.NewBuffer(AppDataHeader)
|
||||||
write, err := m.Conn.Write(t)
|
packetBuf.Write(lenNum)
|
||||||
|
packetBuf.Write(p)
|
||||||
|
|
||||||
|
write, err := m.Conn.Write(packetBuf.Bytes())
|
||||||
write = write - HeaderLength - 2
|
write = write - HeaderLength - 2
|
||||||
return write, err
|
return write, err
|
||||||
}
|
}
|
||||||
|
@ -70,8 +70,66 @@ func handler(conn net.Conn, targetAddress string, fakeAddress string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
p := &PackAppData{Conn: conn}
|
p := &PackAppData{Conn: conn}
|
||||||
go io.Copy(realConnection, p)
|
|
||||||
go io.Copy(p, realConnection)
|
defer p.Close()
|
||||||
|
defer realConnection.Close()
|
||||||
|
exit := make(chan int, 1)
|
||||||
|
|
||||||
|
go MyCopy(p, realConnection, exit)
|
||||||
|
go MyCopy(realConnection, p, exit)
|
||||||
|
<-exit
|
||||||
|
|
||||||
|
//go func() {
|
||||||
|
// buf := make([]byte, 64*1024)
|
||||||
|
// for {
|
||||||
|
// nr, er := realConnection.Read(buf)
|
||||||
|
// if er != nil {
|
||||||
|
// if er == io.EOF {
|
||||||
|
// continue
|
||||||
|
// } else {
|
||||||
|
// fmt.Println("read err:", er)
|
||||||
|
// break
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// lenNum := make([]byte, 2)
|
||||||
|
// binary.BigEndian.PutUint16(lenNum, uint16(nr))
|
||||||
|
//
|
||||||
|
// packetBuf := bytes.NewBuffer(AppDataHeader)
|
||||||
|
// packetBuf.Write(lenNum)
|
||||||
|
// packetBuf.Write(buf[0:nr])
|
||||||
|
//
|
||||||
|
// _, ew := conn.Write(packetBuf.Bytes())
|
||||||
|
// if ew != nil {
|
||||||
|
// fmt.Printf("err2:%v\n", ew)
|
||||||
|
// break
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
//}()
|
||||||
|
//
|
||||||
|
//go func() {
|
||||||
|
// result := bytes.NewBuffer(nil)
|
||||||
|
// var buf [65542]byte // 由于 标识数据包长度 的只有两个字节 故数据包最大为 2^16+4(魔数)+2(长度标识)
|
||||||
|
// for {
|
||||||
|
// n, er := conn.Read(buf[0:])
|
||||||
|
// result.Write(buf[0:n])
|
||||||
|
// if er != nil {
|
||||||
|
// if er == io.EOF {
|
||||||
|
// continue
|
||||||
|
// } else {
|
||||||
|
// fmt.Println("read err:", er)
|
||||||
|
// break
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// scanner := bufio.NewScanner(result)
|
||||||
|
// scanner.Split(packetSlitFunc)
|
||||||
|
// for scanner.Scan() {
|
||||||
|
// realConnection.Write(scanner.Bytes()[HeaderLength+2:])
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// result.Reset()
|
||||||
|
// }
|
||||||
|
//}()
|
||||||
}
|
}
|
||||||
|
|
||||||
func processHandshake(src net.Conn, dst net.Conn, waitCh chan int) {
|
func processHandshake(src net.Conn, dst net.Conn, waitCh chan int) {
|
||||||
|
Loading…
Reference in New Issue
Block a user