
org.bbottema.javasocksproxyserver.SocksServer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-socks-proxy-server Show documentation
Show all versions of java-socks-proxy-server Show documentation
java-socks-proxy-server is a SOCKS 4/5 server for Java
/*
* Copyright (C) 2019 Benny Bottema ([email protected])
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.bbottema.javasocksproxyserver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.io.InterruptedIOException;
import java.net.ServerSocket;
import java.net.Socket;
public class SocksServer {
private static final Logger LOGGER = LoggerFactory.getLogger(SocksServer.class);
protected int port;
protected boolean stopping = false;
public int getPort() {
return port;
}
public synchronized void start(int listenPort) {
this.stopping = false;
this.port = listenPort;
new Thread(new ServerProcess()).start();
}
public synchronized void stop() {
stopping = true;
}
private class ServerProcess implements Runnable {
@Override
public void run() {
LOGGER.debug("SOCKS server started...");
try {
handleClients(port);
LOGGER.debug("SOCKS server stopped...");
} catch (IOException e) {
LOGGER.debug("SOCKS server crashed...");
Thread.currentThread().interrupt();
}
}
protected void handleClients(int port) throws IOException {
final ServerSocket listenSocket = new ServerSocket(port);
listenSocket.setSoTimeout(SocksConstants.LISTEN_TIMEOUT);
SocksServer.this.port = listenSocket.getLocalPort();
LOGGER.debug("SOCKS server listening at port: " + listenSocket.getLocalPort());
while (true) {
synchronized (SocksServer.this) {
if (stopping) {
break;
}
}
handleNextClient(listenSocket);
}
try {
listenSocket.close();
} catch (IOException e) {
// ignore
}
}
private void handleNextClient(ServerSocket listenSocket) {
try {
final Socket clientSocket = listenSocket.accept();
clientSocket.setSoTimeout(SocksConstants.DEFAULT_SERVER_TIMEOUT);
LOGGER.debug("Connection from : " + Utils.getSocketInfo(clientSocket));
new Thread(new ProxyHandler(clientSocket)).start();
} catch (InterruptedIOException e) {
// This exception is thrown when accept timeout is expired
} catch (Exception e) {
LOGGER.error(e.getMessage(), e);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy