本文整理汇总了Java中javax.net.ssl.SSLException.initCause方法的典型用法代码示例。如果您正苦于以下问题:Java SSLException.initCause方法的具体用法?Java SSLException.initCause怎么用?Java SSLException.initCause使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类javax.net.ssl.SSLException
的用法示例。
在下文中一共展示了SSLException.initCause方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: messageReceived
import javax.net.ssl.SSLException; //导入方法依赖的package包/类
@Override
public void messageReceived(NextFilter nextFilter, IoSession session, Object message) throws SSLException {
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("{}: Message received : {}", getSessionInfo(session), message);
}
SslHandler handler = getSslSessionHandler(session);
synchronized (handler) {
if (!isSslStarted(session) && handler.isInboundDone()) {
// The SSL session must be established first before we
// can push data to the application. Store the incoming
// data into a queue for a later processing
handler.scheduleMessageReceived(nextFilter, message);
} else {
IoBuffer buf = (IoBuffer) message;
try {
// forward read encrypted data to SSL handler
handler.messageReceived(nextFilter, buf.buf());
// Handle data to be forwarded to application or written to net
handleSslData(nextFilter, handler);
if (handler.isInboundDone()) {
if (handler.isOutboundDone()) {
handler.destroy();
} else {
initiateClosure(nextFilter, session);
}
if (buf.hasRemaining()) {
// Forward the data received after closure.
handler.scheduleMessageReceived(nextFilter, buf);
}
}
} catch (SSLException ssle) {
if (!handler.isHandshakeComplete()) {
SSLException newSsle = new SSLHandshakeException("SSL handshake failed.");
newSsle.initCause(ssle);
ssle = newSsle;
}
throw ssle;
}
}
}
handler.flushScheduledEvents();
}