diff --git a/component/sniffer/dispatcher.go b/component/sniffer/dispatcher.go index cca8f719..82a400e6 100644 --- a/component/sniffer/dispatcher.go +++ b/component/sniffer/dispatcher.go @@ -76,9 +76,13 @@ func (sd *SnifferDispatcher) TCPSniff(conn net.Conn, metadata *C.Metadata) { } func (sd *SnifferDispatcher) replaceDomain(metadata *C.Metadata, host string) { + dstIP := "" + if metadata.DstIP.IsValid() { + dstIP = metadata.DstIP.String() + } log.Debugln("[Sniffer] Sniff TCP [%s:%s]-->[%s:%s] success, replace domain [%s]-->[%s]", metadata.SrcIP, metadata.SrcPort, - metadata.DstIP, metadata.DstPort, + dstIP, metadata.DstPort, metadata.Host, host) metadata.AddrType = C.AtypDomainName diff --git a/tunnel/tunnel.go b/tunnel/tunnel.go index b83da180..aec6da01 100644 --- a/tunnel/tunnel.go +++ b/tunnel/tunnel.go @@ -269,7 +269,7 @@ func handleUDPConn(packet *inbound.PacketAdapter) { ctx, cancel := context.WithTimeout(context.Background(), C.DefaultUDPTimeout) defer cancel() - rawPc, err := proxy.ListenPacketContext(ctx, metadata) + rawPc, err := proxy.ListenPacketContext(ctx, metadata.Pure()) if err != nil { if rule == nil { log.Warnln("[UDP] dial %s to %s error: %s", proxy.Name(), metadata.RemoteAddress(), err.Error())