龙将斩千 v5.5.5.39856版本的 MD5 值为:5c05b1d6f8d872ca3fe0343d6ff07caf
以下内容为反编译后的 SocketReceiver.java 源代码,内容仅作参考
package ch.qos.logback.classic.net;
import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.LoggerContext;
import ch.qos.logback.classic.net.server.HardenedLoggingEventInputStream;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.net.DefaultSocketConnector;
import ch.qos.logback.core.net.SocketConnector;
import ch.qos.logback.core.util.CloseUtil;
import java.io.Closeable;
import java.io.EOFException;
import java.io.IOException;
import java.net.ConnectException;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import java.util.concurrent.RejectedExecutionException;
import javax.net.SocketFactory;
public class SocketReceiver extends ReceiverBase implements Runnable, SocketConnector.ExceptionHandler {
private static final int DEFAULT_ACCEPT_CONNECTION_DELAY = 5000;
private int acceptConnectionTimeout = 5000;
private InetAddress address;
private Future<Socket> connectorTask;
private int port;
private String receiverId;
private int reconnectionDelay;
private String remoteHost;
private volatile Socket socket;
private Future<Socket> activateConnector(SocketConnector socketConnector) {
try {
return getContext().getScheduledExecutorService().submit(socketConnector);
} catch (RejectedExecutionException e) {
return null;
}
}
private SocketConnector createConnector(InetAddress inetAddress, int i, int i2, int i3) {
SocketConnector newConnector = newConnector(inetAddress, i, i2, i3);
newConnector.setExceptionHandler(this);
newConnector.setSocketFactory(getSocketFactory());
return newConnector;
}
private void dispatchEvents(LoggerContext loggerContext) {
HardenedLoggingEventInputStream hardenedLoggingEventInputStream;
StringBuilder sb;
try {
try {
this.socket.setSoTimeout(this.acceptConnectionTimeout);
hardenedLoggingEventInputStream = new HardenedLoggingEventInputStream(this.socket.getInputStream());
try {
this.socket.setSoTimeout(0);
addInfo(this.receiverId + "connection established");
while (true) {
ILoggingEvent iLoggingEvent = (ILoggingEvent) hardenedLoggingEventInputStream.readObject();
Logger logger = loggerContext.getLogger(iLoggingEvent.getLoggerName());
if (logger.isEnabledFor(iLoggingEvent.getLevel())) {
logger.callAppenders(iLoggingEvent);
}
}
} catch (EOFException e) {
addInfo(this.receiverId + "end-of-stream detected");
CloseUtil.closeQuietly(hardenedLoggingEventInputStream);
CloseUtil.closeQuietly(this.socket);
this.socket = null;
sb = new StringBuilder();
sb.append(this.receiverId);
sb.append("connection closed");
addInfo(sb.toString());
} catch (IOException e2) {
e = e2;
addInfo(this.receiverId + "connection failed: " + e);
CloseUtil.closeQuietly(hardenedLoggingEventInputStream);
CloseUtil.closeQuietly(this.socket);
this.socket = null;
sb = new StringBuilder();
sb.append(this.receiverId);
sb.append("connection closed");
addInfo(sb.toString());
} catch (ClassNotFoundException e3) {
e = e3;
addInfo(this.receiverId + "unknown event class: " + e);
CloseUtil.closeQuietly(hardenedLoggingEventInputStream);
CloseUtil.closeQuietly(this.socket);
this.socket = null;
sb = new StringBuilder();
sb.append(this.receiverId);
sb.append("connection closed");
addInfo(sb.toString());
}
} catch (Throwable th) {
th = th;
CloseUtil.closeQuietly((Closeable) null);
CloseUtil.closeQuietly(this.socket);
this.socket = null;
addInfo(this.receiverId + "connection closed");
throw th;
}
} catch (EOFException e4) {
hardenedLoggingEventInputStream = null;
} catch (IOException e5) {
e = e5;
hardenedLoggingEventInputStream = null;
} catch (ClassNotFoundException e6) {
e = e6;
hardenedLoggingEventInputStream = null;
} catch (Throwable th2) {
th = th2;
CloseUtil.closeQuietly((Closeable) null);
CloseUtil.closeQuietly(this.socket);
this.socket = null;
addInfo(this.receiverId + "connection closed");
throw th;
}
}
private Socket waitForConnectorToReturnASocket() throws InterruptedException {
try {
Socket socket = this.connectorTask.get();
this.connectorTask = null;
return socket;
} catch (ExecutionException e) {
return null;
}
}
@Override
public void connectionFailed(SocketConnector socketConnector, Exception exc) {
StringBuilder sb;
String str;
String sb2;
if (exc instanceof InterruptedException) {
sb2 = "connector interrupted";
} else {
if (exc instanceof ConnectException) {
sb = new StringBuilder();
sb.append(this.receiverId);
str = "connection refused";
} else {
sb = new StringBuilder();
sb.append(this.receiverId);
str = "unspecified error";
}
sb.append(str);
sb2 = sb.toString();
}
addWarn(sb2, exc);
}
@Override
protected Runnable getRunnableTask() {
return this;
}
protected SocketFactory getSocketFactory() {
return SocketFactory.getDefault();
}
protected SocketConnector newConnector(InetAddress inetAddress, int i, int i2, int i3) {
return new DefaultSocketConnector(inetAddress, i, i2, i3);
}
@Override
protected void onStop() {
if (this.socket != null) {
CloseUtil.closeQuietly(this.socket);
}
}
@Override
public void run() {
try {
LoggerContext loggerContext = (LoggerContext) getContext();
while (!Thread.currentThread().isInterrupted()) {
this.connectorTask = activateConnector(createConnector(this.address, this.port, 0, this.reconnectionDelay));
if (this.connectorTask == null) {
break;
}
this.socket = waitForConnectorToReturnASocket();
if (this.socket == null) {
break;
} else {
dispatchEvents(loggerContext);
}
}
} catch (InterruptedException e) {
}
addInfo("shutting down");
}
public void setAcceptConnectionTimeout(int i) {
this.acceptConnectionTimeout = i;
}
public void setPort(int i) {
this.port = i;
}
public void setReconnectionDelay(int i) {
this.reconnectionDelay = i;
}
public void setRemoteHost(String str) {
this.remoteHost = str;
}
@Override
public boolean shouldStart() {
int i;
if (this.port == 0) {
addError("No port was configured for receiver. For more information, please visit http://logback.qos.ch/codes.html#receiver_no_port");
i = 1;
} else {
i = 0;
}
if (this.remoteHost == null) {
i++;
addError("No host name or address was configured for receiver. For more information, please visit http://logback.qos.ch/codes.html#receiver_no_host");
}
if (this.reconnectionDelay == 0) {
this.reconnectionDelay = 30000;
}
if (i == 0) {
try {
this.address = InetAddress.getByName(this.remoteHost);
} catch (UnknownHostException e) {
addError("unknown host: " + this.remoteHost);
i++;
}
}
if (i == 0) {
this.receiverId = "receiver " + this.remoteHost + ":" + this.port + ": ";
}
return i == 0;
}
}