From de686ec446b786a7f30089da0b900ce634922737 Mon Sep 17 00:00:00 2001 From: ulrich Date: Sat, 27 Mar 2021 17:44:54 +0000 Subject: [PATCH] Kommentare ergaenzt --- src/de/uhilger/minsrv/handler/StopServerHandler.java | 46 ++++++++++++++++++++++++++++++++++------------ 1 files changed, 34 insertions(+), 12 deletions(-) diff --git a/src/de/uhilger/minsrv/handler/StopServerHandler.java b/src/de/uhilger/minsrv/handler/StopServerHandler.java index e1960dd..1d21ae0 100644 --- a/src/de/uhilger/minsrv/handler/StopServerHandler.java +++ b/src/de/uhilger/minsrv/handler/StopServerHandler.java @@ -14,8 +14,7 @@ You should have received a copy of the GNU Affero General Public License along with this program. If not, see <https://www.gnu.org/licenses/>. -*/ - + */ package de.uhilger.minsrv.handler; import com.sun.net.httpserver.HttpExchange; @@ -23,28 +22,51 @@ import de.uhilger.minsrv.App; import java.io.IOException; import java.io.OutputStream; +import java.util.Timer; +import java.util.TimerTask; import java.util.logging.Logger; /** * Ein HTTP-Handler zum Stoppen der Anwendung - * + * * @author Ulrich Hilger */ public class StopServerHandler implements HttpHandler { + /** + * Den Server geordnet herunterfahren und + * dann die Anwendung beenden. + * + * @param e das Objekt mit Methoden zur Untersuchung der Anfrage sowie zum + * Anfertigen und Senden der Antwort + * @throws IOException falls etwas schief geht entsteht dieser Fehler + */ @Override - public void handle(HttpExchange exchange) throws IOException { - Logger.getLogger(StopServerHandler.class.getName()).info(exchange.getRequestURI().toString()); + public void handle(HttpExchange e) throws IOException { + Logger.getLogger(StopServerHandler.class.getName()).info(e.getRequestURI().toString()); String response = "Server stopped"; - exchange.sendResponseHeaders(200, response.length()); - OutputStream os = exchange.getResponseBody(); + e.sendResponseHeaders(200, response.length()); + OutputStream os = e.getResponseBody(); os.write(response.getBytes()); os.flush(); os.close(); - Logger.getLogger(StopServerHandler.class.getName()).info("stopping app."); - App.stop(); - //exchange.getHttpContext().getServer().stop(5); + Logger.getLogger(StopServerHandler.class.getName()).info("stopping server."); + e.getHttpContext().getServer().stop(1); + Timer timer = new Timer(); + timer.schedule(new AppStopper(), 2000); } - - + + /** + * Die Klasse AppStopper ermöglicht das asnychrone bzw. + * zeitgesteuerte Stoppen der Anwendung. + */ + class AppStopper extends TimerTask { + + @Override + public void run() { + Logger.getLogger(StopServerHandler.class.getName()).info("Mini-Server beendet."); + App.stop(); + } + } + } -- Gitblit v1.9.3