當前位置: 首頁>>代碼示例>>Java>>正文


Java DatagramPacket.sender方法代碼示例

本文整理匯總了Java中io.netty.channel.socket.DatagramPacket.sender方法的典型用法代碼示例。如果您正苦於以下問題:Java DatagramPacket.sender方法的具體用法?Java DatagramPacket.sender怎麽用?Java DatagramPacket.sender使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在io.netty.channel.socket.DatagramPacket的用法示例。


在下文中一共展示了DatagramPacket.sender方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: channelRead

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) {
    if (msg instanceof DatagramPacket) {
        // Get packet and sender data
        DatagramPacket datagram = (DatagramPacket) msg;
        InetSocketAddress sender = datagram.sender();
        RakNetPacket packet = new RakNetPacket(datagram);

        // If an exception happens it's because of this address
        this.causeAddress = sender;

        // Handle the packet and release the buffer
        client.handleMessage(packet, sender);
        datagram.content().readerIndex(0); // Reset position
        client.getListener().handleNettyMessage(datagram.content(), sender);
        datagram.content().release(); // No longer needed

        // No exceptions occurred, release the suspect
        this.causeAddress = null;
    }
}
 
開發者ID:KernelFreeze,項目名稱:BedrockProxy,代碼行數:22,代碼來源:RakNetClientHandler.java

示例2: createListenerHandler

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
private SimpleChannelInboundHandler<DatagramPacket> createListenerHandler(SeedNode thisNode, ByteBuf seedNodeInfo) {
    return new SimpleChannelInboundHandler<DatagramPacket>() {
        @Override
        public void channelRead0(ChannelHandlerContext ctx, DatagramPacket msg) throws Exception {
            ByteBuf buf = msg.content();

            if (buf.readableBytes() > 4 && buf.readInt() == Utils.MAGIC_BYTES) {
                MessageTYpe msgType = MessageTYpe.values()[buf.readByte()];

                if (msgType == MessageTYpe.DISCOVERY) {
                    String cluster = decodeUtf(buf);
                    InetSocketAddress address = decodeAddress(buf);

                    if (thisNode.cluster().equals(cluster) && !address.equals(thisNode.address())) {
                        onDiscoveryMessage(address);

                        DatagramPacket response = new DatagramPacket(seedNodeInfo.copy(), msg.sender());

                        ctx.writeAndFlush(response);
                    }
                }
            }
        }
    };
}
 
開發者ID:hekate-io,項目名稱:hekate,代碼行數:26,代碼來源:MulticastSeedNodeProvider.java

示例3: channelRead0

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
protected void channelRead0(ChannelHandlerContext ctx, DatagramPacket msg) throws Exception {
	channel = ctx.channel();
	sender = msg.sender();

	ByteBuf content = msg.content();
	
	int methodID = content.readInt();
	int invID = content.readInt();
	int argCount = content.readInt();
	Object[] args = new Object[argCount];
	for(int i = 0; i < argCount; i++) {
		Class<?> clazz = Class.forName(readString(content));
		args[i] = gson.fromJson(readString(content), clazz);
	}

	provider.invoke(methodID, invID, args);
}
 
開發者ID:thilokru,項目名稱:Controller-Support,代碼行數:19,代碼來源:NetworkHandler.java

示例4: channelRead0

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
protected void channelRead0(ChannelHandlerContext ctx, DatagramPacket msg) throws Exception {
    final SocketAddress remoteAddress = msg.sender();
    final CodecAggregator.Result result;
    try (Timer.Context ignored = aggregationTimer.time()) {
        result = aggregator.addChunk(msg.content(), remoteAddress);
    }
    final ByteBuf completeMessage = result.getMessage();
    if (completeMessage != null) {
        LOG.debug("Message aggregation completion, forwarding {}", completeMessage);
        ctx.fireChannelRead(completeMessage);
    } else if (result.isValid()) {
        LOG.debug("More chunks necessary to complete this message");
    } else {
        invalidChunksMeter.mark();
        LOG.debug("Message chunk was not valid and discarded.");
    }
}
 
開發者ID:Graylog2,項目名稱:graylog-plugin-netflow,代碼行數:19,代碼來源:NetflowMessageAggregationHandler.java

示例5: decode

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
/**
   * Decodes a {@link DatagramPacket} to a {@link DataPacket} wrapped into an {@link AddressedEnvelope} to allow multicast on
   * the used {@link SocketChannel}. 
   * 
   * @param ctx The context of the ChannelHandler
   * @param msg the message which should be encoded
   * @param out a list where all messages are written to
   */
  @Override
  protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws Exception {
  	final ByteBuf content = msg.content();
final SocketAddress sender = msg.sender();
final SocketAddress recipient = msg.recipient();

      try {
          final DataPacket dataPacket = DataPacket.decode(content);
          final AddressedEnvelope<DataPacket, SocketAddress> newMsg = 
  				new DefaultAddressedEnvelope<>(
  						dataPacket, recipient, sender);
  		out.add(newMsg);
      } catch (Exception e) {
          LOG.debug("Failed to decode RTP packet.", e);
      }
  }
 
開發者ID:SAS-Systems,項目名稱:imflux,代碼行數:25,代碼來源:UdpDataPacketDecoder.java

示例6: channelRead

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
    if (msg instanceof DatagramPacket) {
        // Get packet and sender data
        DatagramPacket datagram = (DatagramPacket) msg;
        InetSocketAddress sender = datagram.sender();
        RakNetPacket packet = new RakNetPacket(datagram);

        // If an exception happens it's because of this address
        this.causeAddress = sender;

        // Is the sender blocked?
        if (this.addressBlocked(sender.getAddress())) {
            BlockedAddress status = blocked.get(sender.getAddress());
            if (status.getTime() <= BlockedAddress.PERMANENT_BLOCK) {
                return; // Permanently blocked
            }
            if (System.currentTimeMillis() - status.getStartTime() < status.getTime()) {
                return; // Time hasn't expired
            }
            this.unblockAddress(sender.getAddress());
        }

        // Handle the packet and release the buffer
        server.handleMessage(packet, sender);
        datagram.content().readerIndex(0); // Reset position
        server.getListener().handleNettyMessage(datagram.content(), sender);
        datagram.content().release(); // No longer needed

        // No exceptions occurred, release the suspect
        this.causeAddress = null;
    }
}
 
開發者ID:KernelFreeze,項目名稱:BedrockProxy,代碼行數:34,代碼來源:RakNetServerHandler.java

示例7: channelRead

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
    DatagramPacket datagram = (DatagramPacket) msg;
    InetSocketAddress sender = datagram.sender();
    Channel tcpChannel = XChannelMapper.getTcpChannel(sender);
    if (tcpChannel == null) {
        // udpSource not registered, actively discard this packet
        // without register, an udp channel cannot relate to any tcp channel, so remove the map
        XChannelMapper.removeUdpMapping(sender);
        log.warn("Bad Connection! (unexpected udp datagram from {})", sender);
    } else if (tcpChannel.isActive()) {
        ByteBuf byteBuf = datagram.content();
        try {
            if (!byteBuf.hasArray()) {
                byte[] bytes = new byte[byteBuf.readableBytes()];
                byteBuf.getBytes(0, bytes);
                log.info("\t          Proxy << Target \tFrom   {}:{}", sender.getHostString(), sender.getPort());

                // write udp payload via tcp channel
                tcpChannel.writeAndFlush(Unpooled.wrappedBuffer(wrapper.wrap(requestResolver.wrap(XRequest.Channel.UDP, bytes))));
                log.info("\tClient << Proxy           \tGet [{} bytes]", bytes.length);
            }
        } finally {
            ReferenceCountUtil.release(msg);
        }
    }
}
 
開發者ID:ZhangJiupeng,項目名稱:AgentX,代碼行數:28,代碼來源:Udp2TcpHandler.java

示例8: decode

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
public void decode(ChannelHandlerContext ctx, DatagramPacket packet, List<Object> out) throws Exception {
    ByteBuf buf = packet.content();
    byte[] encoded = new byte[buf.readableBytes()];
    buf.readBytes(encoded);
    try {
        Message msg = Message.decode(encoded);
        DiscoveryEvent event = new DiscoveryEvent(msg, packet.sender());
        out.add(event);
    } catch (Exception e) {
        throw new RuntimeException("Exception processing inbound message from " + ctx.channel().remoteAddress() + ": " + Hex.toHexString(encoded), e);
    }
}
 
開發者ID:talentchain,項目名稱:talchain,代碼行數:14,代碼來源:PacketDecoder.java

示例9: decode

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws Exception {
	ByteBuf buf = msg.content();
	int i = buf.indexOf(0, buf.readableBytes(), LogEvent.SEPARATOR);
	String filename = buf.slice(0, i).toString(CharsetUtil.UTF_8);
	String logMsg = buf.slice(i + 1, buf.readableBytes()).toString(CharsetUtil.UTF_8);
	LogEvent event = new LogEvent(msg.sender(), System.currentTimeMillis(), filename, logMsg);
	out.add(event);
}
 
開發者ID:janzolau1987,項目名稱:study-netty,代碼行數:10,代碼來源:LogEventDecoder.java

示例10: sendDiscoveryResponse

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
/**
 * Send a response with the ConnectInformation of this Master to the requesting Client.
 *
 * @param request the request sent from a {@link Client}
 */
private void sendDiscoveryResponse(DatagramPacket request) {
    final ByteBuf buffer = channel.channel().alloc().heapBuffer();

    // gather information
    final byte[] header = DISCOVERY_PAYLOAD_RESPONSE.getBytes();
    final String addressString = request.recipient().getAddress().getHostAddress();
    final byte[] address = addressString.getBytes();
    final InetSocketAddress serverAddress = requireComponent(Server.KEY).getAddress();
    if (serverAddress == null) {
        Log.w(TAG, "Could not respond to UDP discovery request as Server is not started yet");
        return;
    }
    final int port = serverAddress.getPort();
    Log.i(TAG, "sendDiscoveryResponse with connection data " + addressString + ":" + port + " to " + request.sender());

    // write it to the buffer
    buffer.writeInt(header.length);
    buffer.writeBytes(header);
    buffer.writeInt(address.length);
    buffer.writeBytes(address);
    buffer.writeInt(port);

    // and sign the data
    try {
        Signature signature = Signature.getInstance("ECDSA");
        signature.initSign(requireComponent(KeyStoreController.KEY).getOwnPrivateKey());
        signature.update(buffer.nioBuffer());
        final byte[] sign = signature.sign();
        buffer.writeInt(sign.length);
        buffer.writeBytes(sign);
    } catch (GeneralSecurityException e) {
        Log.w(TAG, "Could not send UDP discovery response", e);
    }

    final DatagramPacket response = new DatagramPacket(buffer, request.sender());
    channel.channel().writeAndFlush(response);
}
 
開發者ID:SecureSmartHome,項目名稱:SecureSmartHome,代碼行數:43,代碼來源:UDPDiscoveryServer.java

示例11: decode

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws Exception {
    if (filter(msg)) {
        InetSocketAddress sender = msg.sender();
        LOG.info("Access denied for host(IP) : [" + sender.getHostName() + ":" + sender.getPort() + "].");
        return;
    }
    String data = translate(msg);
    if (data == null) {
        LOG.info("The message data is null.");
        return;
    }
    out.add(data);
}
 
開發者ID:ogcs,項目名稱:Okra-LOG,代碼行數:15,代碼來源:UdpProtocolHandler.java

示例12: onReceive

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
/**
 * receive DatagramPacket
 *
 * @param dp
 */
private void onReceive(DatagramPacket dp)
{
  if (this.running)
  {
    InetSocketAddress sender = dp.sender();
    int hash = sender.hashCode();
    hash = hash < 0 ? -hash : hash;
    this.workers[hash % workers.length].input(dp);
  } else
  {
    dp.release();
  }
}
 
開發者ID:beykery,項目名稱:jkcp,代碼行數:19,代碼來源:KcpServer.java

示例13: decode

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws Exception {
    // decode the DatagramPackage to AddressedEnvelope
    DefaultAddressedEnvelope<Object, InetSocketAddress> addressEvelop = 
        new DefaultAddressedEnvelope<Object, InetSocketAddress>(msg.content().retain(), msg.recipient(), msg.sender());
    out.add(addressEvelop);
    
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:9,代碼來源:DatagramPacketDecoder.java

示例14: receive

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
public void receive(ChannelHandlerContext ctx, DatagramPacket packet) {
	ByteBuf content = packet.content();
	Message message = config.serialiser.deserialiseWithStream(new ByteBufInputStream(content));
	if (message == null) {
		return;
	}
	// TODO set config and state
	message.payload = content;
	if (message.getFeatures() != null) {
		message.getFeatures().resolve();
	}

	if (config.debug.simulateLossOfPacket()) {
		// simulated N % loss rate
		log.warn("DEBUG: simulated loss of packet: {}", message);
		return;
	}

	message.socketAddressSender = packet.sender();
	message.socketAddressRecipient = packet.recipient();

	if (config.trackData) {
		int frame = 0;
		config.netStats.getData().add(
				new NetStats.Line(false, message.getSenderId(), frame, message.getTimestamp(), message.getClass(), ((ByteBuf)message.payload).writerIndex()));
	}

	// Let the controller receive the message.
	// Processors are called there.
	config.internalReceiver.receive(message);
}
 
開發者ID:klaus7,項目名稱:jfastnet,代碼行數:32,代碼來源:KryoNettyPeer.java

示例15: decode

import io.netty.channel.socket.DatagramPacket; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws
        Exception {
    ctx.attr(PipelineUtils.ADDRESS_ATTRIBUTE).set(msg.sender());
    byte packetId = msg.content().readByte();

    PacketHeader header = new PacketHeader(packetId);
    Server.getServer().getLogger().debug(PocketLogging.Server.NETWORK, header.toString());

    Packet packet = PacketRegistry.construct(packetId);

    Object[] params = new Object[]{
            null,
            msg.sender()
    };

    if (Server.getServer().getLogger().isTraceEnabled()) {
        params[0] = packet.toString();
    } else {
        params[0] = String.format("0x%02X", packetId);
    }
    Server.getServer().getLogger().debug(PocketLogging.Server.NETWORK, "Received {} from {}",
            params);
    packet.record(this);
    try {
        packet.read(msg.content());
        out.add(packet);
    } finally {
        packet.close();
    }
}
 
開發者ID:PocketServer,項目名稱:PocketServer-Ref,代碼行數:32,代碼來源:PacketDecoder.java


注:本文中的io.netty.channel.socket.DatagramPacket.sender方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。