diff options
-rw-r--r-- | debug.xml | 5 | ||||
-rw-r--r-- | src/main/java/org/traccar/broadcast/MulticastBroadcastService.java | 6 |
2 files changed, 7 insertions, 4 deletions
@@ -24,7 +24,8 @@ <entry key='atrack.custom'>true</entry> <entry key='intellitrac.port'>6037</entry> - <!--<entry key='broadcast.address'>230.0.0.0</entry> - <entry key='broadcast.port'>5000</entry>--> + <!--<entry key='broadcast.interface'>en0</entry> + <entry key='broadcast.address'>230.3.3.3</entry> + <entry key='broadcast.port'>7001</entry>--> </properties> diff --git a/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java b/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java index c4ba0e059..be24989dd 100644 --- a/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java +++ b/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java @@ -167,8 +167,10 @@ public class MulticastBroadcastService implements BroadcastService { while (!service.isShutdown()) { DatagramPacket packet = new DatagramPacket(receiverBuffer, receiverBuffer.length); socket.receive(packet); - String data = new String(packet.getData(), 0, packet.getLength(), StandardCharsets.UTF_8); - handleMessage(objectMapper.readValue(data, BroadcastMessage.class)); + if (networkInterface.inetAddresses().noneMatch(a -> a.equals(packet.getAddress()))) { + String data = new String(packet.getData(), 0, packet.getLength(), StandardCharsets.UTF_8); + handleMessage(objectMapper.readValue(data, BroadcastMessage.class)); + } } publisherSocket = null; socket.leaveGroup(group, networkInterface); |