diff --git a/proxy/trojan/server.go b/proxy/trojan/server.go index 6e51829f9..2e3fff740 100644 --- a/proxy/trojan/server.go +++ b/proxy/trojan/server.go @@ -207,7 +207,9 @@ func (s *Server) Process(ctx context.Context, network net.Network, conn internet func (s *Server) handleUDPPayload(ctx context.Context, clientReader *PacketReader, clientWriter *PacketWriter, dispatcher routing.Dispatcher) error { udpServer := udp.NewDispatcher(dispatcher, func(ctx context.Context, packet *udp_proto.Packet) { - common.Must(clientWriter.WriteMultiBufferWithMetadata(buf.MultiBuffer{packet.Payload}, packet.Source)) + if err := clientWriter.WriteMultiBufferWithMetadata(buf.MultiBuffer{packet.Payload}, packet.Source); err != nil { + newError("failed to write response").Base(err).AtWarning().WriteToLog(session.ExportIDToError(ctx)) + } }) inbound := session.InboundFromContext(ctx)