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


Java ChannelHandlerContext.close方法代碼示例

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


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

示例1: onPubAck

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
protected void onPubAck(ChannelHandlerContext ctx, MqttMessage msg) {
    if (!this.connected) {
        logger.debug("Protocol violation: Client {} must first sent a CONNECT message, now received PUBACK message, disconnect the client", this.clientId);
        ctx.close();
        return;
    }

    logger.debug("Message received: Received PUBACK message from client {} user {}", this.clientId, this.userName);

    MqttPacketIdVariableHeader variable = (MqttPacketIdVariableHeader) msg.variableHeader();
    int packetId = variable.packetId();

    // In the QoS 1 delivery protocol, the Sender
    // MUST treat the PUBLISH Packet as “unacknowledged” until it has received the corresponding
    // PUBACK packet from the receiver.
    logger.trace("Remove in-flight: Remove in-flight PUBLISH message {} for client {}", packetId, this.clientId);
    this.redis.removeInFlightMessage(this.clientId, packetId);
}
 
開發者ID:12315jack,項目名稱:j1st-mqtt,代碼行數:19,代碼來源:SyncRedisHandler.java

示例2: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
    ctx.close();

    Throwable error = translateException(cause);
    if (null != operation) {
        operation.caught(error);
        return;
    }

    // idle timeout.
    if (error instanceof FastdfsTimeoutException) {
        LOG.debug(error.getMessage(), error);
        return;
    }

    LOG.error(error.getMessage(), error);
}
 
開發者ID:rodbate,項目名稱:fastdfs-spring-boot,代碼行數:19,代碼來源:FastdfsHandler.java

示例3: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
    cause.printStackTrace();
    ctx.close();
}
 
開發者ID:intuit,項目名稱:karate,代碼行數:6,代碼來源:FeatureServerHandler.java

示例4: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
    ctx.close();
    logger.error("ctx close,cause:",cause);
}
 
開發者ID:all4you,項目名稱:redant,代碼行數:6,代碼來源:PreHandleInterceptor.java

示例5: userEventTriggered

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void userEventTriggered(ChannelHandlerContext ctx, Object evt)
        throws Exception {

    if (LOGGER.isTraceEnabled()) {
        LOGGER.trace("userEventTriggered: {}", evt.getClass().getName());
    }

    // if the channel has been idle, close it
    if (evt == IdleStateEvent.FIRST_READER_IDLE_STATE_EVENT) {
        LOGGER.warn("No data received on channel, closing");
        ctx.close();
    }
}
 
開發者ID:smoketurner,項目名稱:graphiak,代碼行數:15,代碼來源:AuthHandler.java

示例6: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
    if (channel.isDiscoveryMode()) {
        loggerNet.debug("FrameCodec failed: ", cause);
    } else {
        if (cause instanceof IOException) {
            loggerNet.info("FrameCodec failed: " + ctx.channel().remoteAddress() + "(" + cause.getMessage() + ")");
            loggerNet.debug("FrameCodec failed: " + ctx.channel().remoteAddress(), cause);
        } else {
            loggerNet.error("FrameCodec failed: ", cause);
        }
    }
    ctx.close();
}
 
開發者ID:rsksmart,項目名稱:rskj,代碼行數:15,代碼來源:FrameCodecHandler.java

示例7: decode

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) {
    if (in.readableBytes() < AbstractMessageDecoder.MESSAGE_LENGTH) {
        return;
    }

    in.markReaderIndex();
    int messageLength = in.readInt();

    if (messageLength < 0) {
        ctx.close();
    }

    if (in.readableBytes() < messageLength) {
        in.resetReaderIndex();
    } else {
        byte[] messageBody = new byte[messageLength];
        in.readBytes(messageBody);

        try {
            Object obj = util.decode(messageBody);
            out.add(obj);
        } catch (IOException ex) {
            Logger.getLogger(AbstractMessageDecoder.class.getName()).log(Level.SEVERE, null, ex);
        }
    }
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:28,代碼來源:AbstractMessageDecoder.java

示例8: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
  if(!ctx.channel().isOpen() || cause.getMessage().equals("Connection reset by peer")){
    logger.warn("Exception occurred with closed channel.  Connection: {}", connection.getName(), cause);
    return;
  }else{
    logger.error("Exception in RPC communication.  Connection: {}.  Closing connection.", connection.getName(), cause);
    ctx.close();
  }
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:11,代碼來源:RpcExceptionHandler.java

示例9: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
    LOGGER.error("{} : exceptionCaught, message is {}", connectionInfo.toString(client), cause.getMessage());

    outboundChannel.close();
    ctx.close();
}
 
開發者ID:chhsiao90,項目名稱:nitmproxy,代碼行數:8,代碼來源:TlsHandler.java

示例10: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext context, Throwable cause) {
    log.error("Exception inside channel handling pipeline.", cause);
    context.close();
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:6,代碼來源:MessageDecoder.java

示例11: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
    cause.printStackTrace();
    ctx.close();
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:6,代碼來源:NettyClientMessageHandler.java

示例12: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
    LOGGER.warn("Exception while handling request", cause);
    currentState = State.BAD_MESSAGE;
    ctx.close();
}
 
開發者ID:wso2,項目名稱:message-broker,代碼行數:7,代碼來源:AmqpDecoder.java

示例13: channelRead0

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void channelRead0(ChannelHandlerContext ctx, SocksRequest request) throws Exception {
    switch (request.protocolVersion()) {
        case SOCKS4a:
            log.warn("\tBad Handshake! (socks version not supported: 4)");
            ctx.write(new SocksInitResponse(SocksAuthScheme.UNKNOWN));
            if (ctx.channel().isActive()) {
                ctx.writeAndFlush(Unpooled.EMPTY_BUFFER).addListener(ChannelFutureListener.CLOSE);
            }
            break;
        case SOCKS5:
            switch (request.requestType()) {
                case INIT:
                    ctx.pipeline().addFirst(new SocksCmdRequestDecoder());
                    ctx.write(new SocksInitResponse(SocksAuthScheme.NO_AUTH));
                    break;
                case AUTH:
                    ctx.pipeline().addFirst(new SocksCmdRequestDecoder());
                    ctx.write(new SocksAuthResponse(SocksAuthStatus.SUCCESS));
                    break;
                case CMD:
                    switch (((SocksCmdRequest) request).cmdType()) {
                        case UDP:
                            // udp relay only supports IPv4 in this version
                            if (((SocksCmdRequest) request).addressType() != SocksAddressType.IPv4) {
                                ctx.write(new SocksCmdResponse(SocksCmdStatus.ADDRESS_NOT_SUPPORTED, ((SocksCmdRequest) request).addressType()));
                                log.warn("\tBad Handshake! (UDP request addr_type not support: {})", ((SocksCmdRequest) request).addressType());
                                ctx.close();
                                break;
                            }
                        case CONNECT:
                            ctx.pipeline().addLast(new XConnectHandler()); // handover
                            ctx.pipeline().remove(this);
                            ctx.fireChannelRead(request);
                            break;
                        default:
                            ctx.close();
                            log.warn("\tBad Handshake! (command not support: {})", ((SocksCmdRequest) request).cmdType());
                    }
                    break;
                case UNKNOWN:
                    log.warn("\tBad Handshake! (unknown request type: {})", request.requestType());
            }
            break;
        case UNKNOWN:
            log.warn("\tBad Handshake! (unknown protocol version: {}", request.protocolVersion());
            ctx.close();
            break;
    }
}
 
開發者ID:ZhangJiupeng,項目名稱:AgentX,代碼行數:51,代碼來源:Socks5Handler.java

示例14: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
  LOG.error("catch a exception ", cause);
  ctx.close();
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:5,代碼來源:MatrixTransportServerHandler.java

示例15: exceptionCaught

import io.netty.channel.ChannelHandlerContext; //導入方法依賴的package包/類
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
  cause.printStackTrace();
  ctx.close();
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:6,代碼來源:MatrixTransportClientHandler.java


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