2019-01-09 12:33:00 +00:00
|
|
|
package server
|
2018-12-11 08:37:12 +00:00
|
|
|
|
|
|
|
import (
|
2019-01-09 12:33:00 +00:00
|
|
|
"github.com/cnlh/easyProxy/bridge"
|
|
|
|
"github.com/cnlh/easyProxy/utils"
|
2018-12-11 08:37:12 +00:00
|
|
|
"io"
|
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
type UdpModeServer struct {
|
2019-01-09 12:33:00 +00:00
|
|
|
bridge *bridge.Tunnel
|
2019-01-05 19:16:46 +00:00
|
|
|
listener *net.UDPConn
|
2019-01-09 12:33:00 +00:00
|
|
|
udpMap map[string]*utils.Conn
|
2019-01-05 19:16:46 +00:00
|
|
|
config *ServerConfig
|
2018-12-11 08:37:12 +00:00
|
|
|
}
|
|
|
|
|
2019-01-09 12:33:00 +00:00
|
|
|
func NewUdpModeServer(bridge *bridge.Tunnel, cnf *ServerConfig) *UdpModeServer {
|
2018-12-11 08:37:12 +00:00
|
|
|
s := new(UdpModeServer)
|
|
|
|
s.bridge = bridge
|
2019-01-09 12:33:00 +00:00
|
|
|
s.udpMap = make(map[string]*utils.Conn)
|
2019-01-05 19:16:46 +00:00
|
|
|
s.config = cnf
|
2018-12-11 08:37:12 +00:00
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
//开始
|
|
|
|
func (s *UdpModeServer) Start() error {
|
2019-01-09 12:33:00 +00:00
|
|
|
var err error
|
2019-01-05 19:16:46 +00:00
|
|
|
s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP("0.0.0.0"), s.config.TcpPort, ""})
|
2018-12-11 08:37:12 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
data := make([]byte, 1472) //udp数据包大小
|
|
|
|
for {
|
|
|
|
n, addr, err := s.listener.ReadFromUDP(data)
|
|
|
|
if err != nil {
|
|
|
|
if strings.Contains(err.Error(), "use of closed network connection") {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
go s.process(addr, data[:n])
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO:效率问题有待解决
|
|
|
|
func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
|
2019-01-05 19:16:46 +00:00
|
|
|
conn, err := s.bridge.GetTunnel(getverifyval(s.config.VerifyKey), s.config.CompressEncode, s.config.CompressDecode, s.config.Crypt, s.config.Mux)
|
2018-12-30 14:36:15 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
return
|
|
|
|
}
|
2019-01-09 12:33:00 +00:00
|
|
|
if _, err := conn.WriteHost(utils.CONN_UDP, s.config.Target); err != nil {
|
2018-12-11 08:37:12 +00:00
|
|
|
conn.Close()
|
|
|
|
return
|
|
|
|
}
|
2019-01-06 17:52:54 +00:00
|
|
|
if flag, err := conn.ReadFlag(); err == nil {
|
2019-01-07 16:21:02 +00:00
|
|
|
defer func() {
|
2019-01-12 16:09:12 +00:00
|
|
|
if conn != nil && s.config.Mux {
|
2019-01-10 01:33:05 +00:00
|
|
|
conn.WriteTo([]byte(utils.IO_EOF), s.config.CompressEncode, s.config.Crypt)
|
2019-01-07 16:21:02 +00:00
|
|
|
s.bridge.ReturnTunnel(conn, getverifyval(s.config.VerifyKey))
|
|
|
|
} else {
|
2019-01-06 17:52:54 +00:00
|
|
|
conn.Close()
|
2019-01-07 16:21:02 +00:00
|
|
|
}
|
|
|
|
}()
|
2019-01-09 12:33:00 +00:00
|
|
|
if flag == utils.CONN_SUCCESS {
|
2019-01-07 16:21:02 +00:00
|
|
|
conn.WriteTo(data, s.config.CompressEncode, s.config.Crypt)
|
|
|
|
buf := make([]byte, 1024)
|
|
|
|
//conn.conn.SetReadDeadline(time.Now().Add(time.Duration(time.Second * 3)))
|
|
|
|
n, err := conn.ReadFrom(buf, s.config.CompressDecode, s.config.Crypt)
|
|
|
|
if err != nil || err == io.EOF {
|
|
|
|
log.Println("revieve error:", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
s.listener.WriteToUDP(buf[:n], addr)
|
2018-12-11 08:37:12 +00:00
|
|
|
}
|
2019-01-06 17:52:54 +00:00
|
|
|
}
|
2018-12-11 08:37:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *UdpModeServer) Close() error {
|
|
|
|
return s.listener.Close()
|
|
|
|
}
|