udp.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package server
  2. import (
  3. "github.com/cnlh/easyProxy/bridge"
  4. "github.com/cnlh/easyProxy/utils"
  5. "io"
  6. "log"
  7. "net"
  8. "strings"
  9. )
  10. type UdpModeServer struct {
  11. bridge *bridge.Tunnel
  12. listener *net.UDPConn
  13. udpMap map[string]*utils.Conn
  14. config *ServerConfig
  15. }
  16. func NewUdpModeServer(bridge *bridge.Tunnel, cnf *ServerConfig) *UdpModeServer {
  17. s := new(UdpModeServer)
  18. s.bridge = bridge
  19. s.udpMap = make(map[string]*utils.Conn)
  20. s.config = cnf
  21. return s
  22. }
  23. //开始
  24. func (s *UdpModeServer) Start() error {
  25. var err error
  26. s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP("0.0.0.0"), s.config.TcpPort, ""})
  27. if err != nil {
  28. return err
  29. }
  30. data := make([]byte, 1472) //udp数据包大小
  31. for {
  32. n, addr, err := s.listener.ReadFromUDP(data)
  33. if err != nil {
  34. if strings.Contains(err.Error(), "use of closed network connection") {
  35. break
  36. }
  37. continue
  38. }
  39. go s.process(addr, data[:n])
  40. }
  41. return nil
  42. }
  43. //TODO:效率问题有待解决
  44. func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
  45. conn, err := s.bridge.GetTunnel(getverifyval(s.config.VerifyKey), s.config.CompressEncode, s.config.CompressDecode, s.config.Crypt, s.config.Mux)
  46. if err != nil {
  47. log.Println(err)
  48. return
  49. }
  50. if _, err := conn.WriteHost(utils.CONN_UDP, s.config.Target); err != nil {
  51. conn.Close()
  52. return
  53. }
  54. if flag, err := conn.ReadFlag(); err == nil {
  55. defer func() {
  56. if conn != nil && s.config.Mux {
  57. conn.WriteTo([]byte(utils.IO_EOF), s.config.CompressEncode, s.config.Crypt)
  58. s.bridge.ReturnTunnel(conn, getverifyval(s.config.VerifyKey))
  59. } else {
  60. conn.Close()
  61. }
  62. }()
  63. if flag == utils.CONN_SUCCESS {
  64. conn.WriteTo(data, s.config.CompressEncode, s.config.Crypt)
  65. buf := make([]byte, 1024)
  66. //conn.conn.SetReadDeadline(time.Now().Add(time.Duration(time.Second * 3)))
  67. n, err := conn.ReadFrom(buf, s.config.CompressDecode, s.config.Crypt)
  68. if err != nil || err == io.EOF {
  69. log.Println("revieve error:", err)
  70. return
  71. }
  72. s.listener.WriteToUDP(buf[:n], addr)
  73. }
  74. }
  75. }
  76. func (s *UdpModeServer) Close() error {
  77. return s.listener.Close()
  78. }