udp.go 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. package proxy
  2. import (
  3. "net"
  4. "strings"
  5. "github.com/astaxie/beego/logs"
  6. "github.com/cnlh/nps/bridge"
  7. "github.com/cnlh/nps/lib/common"
  8. "github.com/cnlh/nps/lib/conn"
  9. "github.com/cnlh/nps/lib/file"
  10. "github.com/cnlh/nps/lib/pool"
  11. )
  12. type UdpModeServer struct {
  13. BaseServer
  14. listener *net.UDPConn
  15. }
  16. func NewUdpModeServer(bridge *bridge.Bridge, task *file.Tunnel) *UdpModeServer {
  17. s := new(UdpModeServer)
  18. s.bridge = bridge
  19. s.task = task
  20. return s
  21. }
  22. //开始
  23. func (s *UdpModeServer) Start() error {
  24. var err error
  25. if s.task.ServerIp == "" {
  26. s.task.ServerIp = "0.0.0.0"
  27. }
  28. s.listener, err = net.ListenUDP("udp", &net.UDPAddr{net.ParseIP(s.task.ServerIp), s.task.Port, ""})
  29. if err != nil {
  30. return err
  31. }
  32. buf := pool.BufPoolUdp.Get().([]byte)
  33. for {
  34. n, addr, err := s.listener.ReadFromUDP(buf)
  35. if err != nil {
  36. if strings.Contains(err.Error(), "use of closed network connection") {
  37. break
  38. }
  39. continue
  40. }
  41. logs.Trace("New udp connection,client %d,remote address %s", s.task.Client.Id, addr)
  42. go s.process(addr, buf[:n])
  43. }
  44. return nil
  45. }
  46. func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
  47. if err := s.CheckFlowAndConnNum(s.task.Client); err != nil {
  48. logs.Warn("client id %d, task id %d,error %s, when udp connection", s.task.Client.Id, s.task.Id, err.Error())
  49. return
  50. }
  51. defer s.task.Client.AddConn()
  52. link := conn.NewLink(common.CONN_UDP, s.task.Target.TargetStr, s.task.Client.Cnf.Crypt, s.task.Client.Cnf.Compress, addr.String(), s.task.Target.LocalProxy)
  53. if target, err := s.bridge.SendLinkInfo(s.task.Client.Id, link, s.task); err != nil {
  54. return
  55. } else {
  56. s.task.Flow.Add(int64(len(data)), 0)
  57. buf := pool.BufPoolUdp.Get().([]byte)
  58. defer pool.BufPoolUdp.Put(buf)
  59. target.Write(data)
  60. s.task.Flow.Add(int64(len(data)), 0)
  61. if n, err := target.Read(buf); err != nil {
  62. logs.Warn(err)
  63. return
  64. } else {
  65. s.listener.WriteTo(buf[:n], addr)
  66. s.task.Flow.Add(0, int64(n))
  67. }
  68. }
  69. }
  70. func (s *UdpModeServer) Close() error {
  71. return s.listener.Close()
  72. }