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


Java DatagramPacket類代碼示例

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


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

示例1: channelRead0

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
@Override
protected void channelRead0(ChannelHandlerContext ctx, DatagramPacket msg) throws Exception {
	ByteBuf buffer = msg.content();
	
	int seq = buffer.readUnsignedShort();
	int msgid = buffer.readByte();
	
	IMessage message = TF2weapons.network.messages[msgid].newInstance();
	//buffer.discardReadBytes();
	message.fromBytes(buffer);
	IMessageHandler<IMessage, IMessage> handler = TF2weapons.network.handlerList.get(message.getClass());
	if(constr == null) {
		constr =MessageContext.class.getDeclaredConstructor(INetHandler.class, Side.class);
		constr.setAccessible(true);
	}
	MessageContext context = constr.newInstance(Minecraft.getMinecraft().player.connection, Side.CLIENT); 
	handler.onMessage(message, context);
	System.out.println("PacketFrom: "+msg.sender().getAddress()+ " "+msg.sender().getPort()+" ");
	
}
 
開發者ID:rafradek,項目名稱:Mods,代碼行數:21,代碼來源:UdpChannelHandlerClient.java

示例2: 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

示例3: 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

示例4: channelActive

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
@Override
public void channelActive(ChannelHandlerContext ctx) throws Exception {
  // Creates the client request
  RtMessage msg = client.createRequest();

  // Encodes the request for network transmission
  ByteBuf encodedMsg = RtWire.toWire(msg);

  // Sends the request to the Roughtime server
  ctx.writeAndFlush(new DatagramPacket(encodedMsg, addr))
      .addListener(fut -> {
        if (!fut.isSuccess()) {
          System.out.println("Send failed " + fut.cause().getMessage());
        }
      });
}
 
開發者ID:int08h,項目名稱:nearenough,代碼行數:17,代碼來源:NettyClient.java

示例5: sendToAll

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
public void sendToAll(IMessage message)
{
		
    if(useUdp && discriminators.containsKey(message.getClass())) {
    	for (EntityPlayer player : TF2weapons.server.getPlayerList().getPlayers()) {
    		InetSocketAddress address=TF2weapons.udpServer.outboundTargets.get(player.getCapability(TF2weapons.PLAYER_CAP, null).udpServerId);
			if(address != null) {
				ByteBuf buffer = Unpooled.buffer();
        		buffer.writeShort(0);
        		buffer.writeByte(discriminators.get(message.getClass()));
        		message.toBytes(buffer);
        		DatagramPacket packet = new DatagramPacket(buffer, address);
        		TF2weapons.udpServer.channel.writeAndFlush(packet);
			}
			else {
				super.sendTo(message, (EntityPlayerMP) player);
			}
		}
    }
    else {
    	super.sendToAll(message);
    }
}
 
開發者ID:rafradek,項目名稱:Mods,代碼行數:24,代碼來源:TF2NetworkWrapper.java

示例6: sendTo

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
public void sendTo(IMessage message, EntityPlayerMP player)
{
    if(useUdp && discriminators.containsKey(message.getClass())) {
    	InetSocketAddress address=TF2weapons.udpServer.outboundTargets.get(player.getCapability(TF2weapons.PLAYER_CAP, null).udpServerId);
    	if (address != null) {
 		ByteBuf buffer = Unpooled.buffer();
 		buffer.writeShort(0);
 		buffer.writeByte(discriminators.get(message.getClass()));
 		message.toBytes(buffer);
 		DatagramPacket packet = new DatagramPacket(buffer, address);
 		TF2weapons.udpServer.channel.writeAndFlush(packet);
    	}
    }
    else {
    	super.sendTo(message, player);
    }
}
 
開發者ID:rafradek,項目名稱:Mods,代碼行數:18,代碼來源:TF2NetworkWrapper.java

示例7: sendToServer

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
public void sendToServer(IMessage message)
{
    if(useUdp && TF2UdpClient.instance != null && discriminators.containsKey(message.getClass())) {
    	InetSocketAddress address=TF2UdpClient.instance.address;
    	//System.out.println("Addr: "+address);
    	if (address != null) {
 		ByteBuf buffer = Unpooled.buffer();
 		buffer.writeShort(TF2UdpClient.playerId);
 		buffer.writeShort(0);
 		buffer.writeByte(discriminators.get(message.getClass()));
 		message.toBytes(buffer);
 		DatagramPacket packet = new DatagramPacket(buffer, address);
 		TF2UdpClient.instance.channel.writeAndFlush(packet);
    	}
    }
    else {
    	super.sendToServer(message);
    }
}
 
開發者ID:rafradek,項目名稱:Mods,代碼行數:20,代碼來源:TF2NetworkWrapper.java

示例8: main

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
	EventLoopGroup loopGroup = new NioEventLoopGroup();
	try{
		Bootstrap b = new Bootstrap();
		b.group(loopGroup).channel(NioDatagramChannel.class)
		.option(ChannelOption.SO_BROADCAST, true)
		.handler(new ChannelProverbClientHandler());
		Channel ch = b.bind(0).sync().channel();
		//向網段內所有的機器廣播UDP消息
		ch.writeAndFlush(
				new DatagramPacket(Unpooled.copiedBuffer("諺語字典查詢?", CharsetUtil.UTF_8),
				new InetSocketAddress("255.255.255.255", port))).sync();
		//客戶端等待15s接受服務端的應答消息,然後退出釋放資源
		if(!ch.closeFuture().await(15000)){
			System.out.println("查詢超時");
		}
	}finally{
		loopGroup.shutdownGracefully();
	}
	
}
 
開發者ID:hdcuican,項目名稱:java_learn,代碼行數:22,代碼來源:ChineseProverbClient.java

示例9: send

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
public void send(ByteBuf msg) throws Exception
{

	byte[] arr = msg.array();
	byte[] buf = new byte[arr.length + id.length];
	System.arraycopy(id, 0, buf, 0, id.length);
	System.arraycopy(arr, 0, buf, id.length, arr.length);

	ByteBuf bbuf = Unpooled.wrappedBuffer(buf);

	if (debug && logger != null)
		logger.info("discovery send " + new String(bbuf.array()));

	datagramChannel.writeAndFlush(
			new DatagramPacket(bbuf, multicastAddress)).sync();

	// datagramChannel.writeAndFlush(buf, multicastAddress);
}
 
開發者ID:yajsw,項目名稱:yajsw,代碼行數:19,代碼來源:MulticastEndpoint.java

示例10: initialize

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
/**
 * Initializes this socket and binds its internal udp socket to a free port.
 * If the socket is already initialized any invocation of this method will
 * result in an IllegalStateException.
 *
 * @throws SocketException Thrown in case the socket could not be initialized
 */
public void initialize() throws SocketException {
    if ( this.isInitialized() ) {
        throw new IllegalStateException( "Cannot re-initialized ClientSocket" );
    }

    this.udpSocket = new Bootstrap();
    this.udpSocket.group( Epoll.isAvailable() ? new EpollEventLoopGroup() : new NioEventLoopGroup() );
    this.udpSocket.channel( Epoll.isAvailable() ? EpollDatagramChannel.class : NioDatagramChannel.class );
    this.udpSocket.handler( new ChannelInboundHandlerAdapter() {
        @Override
        public void channelRead( ChannelHandlerContext ctx, Object msg ) throws Exception {
            io.netty.channel.socket.DatagramPacket packet = (io.netty.channel.socket.DatagramPacket) msg;
            PacketBuffer content = new PacketBuffer( packet.content() );
            InetSocketAddress sender = packet.sender();

            if ( !receiveDatagram( sender, content ) ) {
                // Push datagram to update queue:
                handleDatagram( sender, content, System.currentTimeMillis() );
            }
        }
    } );

    try {
        this.channel = this.udpSocket.bind( ThreadLocalRandom.current().nextInt( 45000, 65000 ) ).sync().channel();
    } catch ( InterruptedException e ) {
        SocketException exception = new SocketException( "Could not bind to socket" );
        exception.initCause( e );
        throw exception;
    }

    this.afterInitialize();
}
 
開發者ID:GoMint,項目名稱:jRakNet,代碼行數:40,代碼來源:ClientSocket.java

示例11: encode

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
@Override
protected void encode(ChannelHandlerContext ctx, PacketWrapper msg, List<Object> out) throws Exception {
    ctx.attr(PipelineUtil.ADDRESS_ATTRIBUTE).set(msg.getRecipient());
    if (msg.getPacket().getType().isRaw()) {
        ctx.write(msg.getPacket());
        return;
    }
    PacketRaknetOutCustomPacket.writeMany(ctx, msg).forEach(outgoing -> {
        ByteBuf buffer = outgoing.getBuffer();
        if (PocketEncoder.dump) {
            PocketServer.getInstance().getLogger().debug("Encoded: {}", ByteBufUtil.hexDump(buffer).toUpperCase());
        }
        Consumer<Session> receipt = msg.getAckReceipt();
        if (receipt != null) {
            Session session = PocketServer.getInstance().getSessions().get(msg.getRecipient());
            session.addAckReceipt(outgoing.getSequenceNumber(), receipt);
        }
        out.add(new DatagramPacket(buffer, msg.getRecipient()));
    });
}
 
開發者ID:PocketServer,項目名稱:PocketServer,代碼行數:21,代碼來源:PocketWrapperEncoder.java

示例12: 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

示例13: sendInvocationResult

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
@Override
public void sendInvocationResult(int invocationID, Object result) {
	ByteBuf buf = Unpooled.buffer();
	buf.writeInt(invocationID);
	String className = result == null ? Void.class.getCanonicalName() : result.getClass().getCanonicalName();
	writeString(buf, className);
	if(result instanceof ByteBuf) {
		ByteBuf res = (ByteBuf) result;
		buf.writeBytes(res);
	} else {
		String json = gson.toJson(result);
		writeString(buf, json);
	}
	
	DatagramPacket msg = new DatagramPacket(buf, sender);
	channel.writeAndFlush(msg);
}
 
開發者ID:thilokru,項目名稱:Controller-Support,代碼行數:18,代碼來源:NetworkHandler.java

示例14: decode

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws Exception {
    //Create our response packet from the datagram we received
    final MasterServerResponsePacket packet = builder.construct(msg.content());
    if (packet != null) {
        final MasterServerResponse response = new MasterServerResponse();
        if (response != null) {
            response.setSender(msg.sender());
            response.setRecipient(msg.recipient());
            response.setResponsePacket(packet);
            log.debug("Receiving Data '{}' from '{}' using Channel Id: {}", response.getClass().getSimpleName(), ctx.channel().remoteAddress(), ctx.channel().id());
            //Pass the message back to the messenger
            responseCallback.accept(response, null);
            return;
        }
    }
    throw new IllegalStateException("No response packet found for the incoming datagram");
}
 
開發者ID:ribasco,項目名稱:async-gamequery-lib,代碼行數:19,代碼來源:MasterServerPacketDecoder.java

示例15: decode

import io.netty.channel.socket.DatagramPacket; //導入依賴的package包/類
@Override
@SuppressWarnings("unchecked")
protected void decode(ChannelHandlerContext ctx, DatagramPacket msg, List<Object> out) throws Exception {
    //Create our response packet from the datagram we received
    final SourceResponsePacket packet = builder.construct(msg.content());
    if (packet != null) {
        try {
            SourceServerResponse response = SourceResponseFactory.createResponseFrom(packet);
            if (response != null) {
                response.setSender(msg.sender());
                response.setRecipient(msg.recipient());
                response.setResponsePacket(packet);
                log.debug("Receiving Data '{}' from '{}' using Channel Id: {}", response.getClass().getSimpleName(), ctx.channel().remoteAddress(), ctx.channel().id());
                //Pass the message back to the messenger
                responseHandler.accept(response, null);
                return;
            }
        } catch (Exception e) {
            responseHandler.accept(null, new AsyncGameLibCheckedException("Error while decoding source query response", e));
        }
    }
    throw new NoResponseFoundForPacket("Could not find a response handler for the received datagram packet", packet);
}
 
開發者ID:ribasco,項目名稱:async-gamequery-lib,代碼行數:24,代碼來源:SourceQueryPacketDecoder.java


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