/*
mini-server - Ein minimalistischer HTTP-Server
Copyright (C) 2021 Ulrich Hilger
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see
Die Hauptklasse des mini-server
* *Folgende Kommandozeilenparameter werden verarbeitet
* *ctx - Kontext des Servers
* www-data - lokales Datenverzeichnis
* port - Port
Beispiel: java -jar mini-server.jar ctx="srv" www-data="/home/fred/www"
* port=9090
Startet den Server auf http://localhost:9090/srv und liefert Inhalte aus
* dem Verzeichnis /home/fred/www
aus.
*
* Ein Aufruf von http://localhost:9090/srv/pfad/zum/inhalt/index.html liefert
* also die Datei 'index.html' aus dem Ordner /home/fred/www/pfad/zum/inhalt
* aus.
Mit http://localhost:9090/srv/server/stop werden Server und App * beendet.
* * @author Ulrich Hilger * @version 0.1, 25.03.2021 */ public class App { private static final Logger logger = Logger.getLogger(App.class.getName()); public static final String IP_PORT = "port"; public static final String IP_WWW_DATA = "www-data"; public static final String IP_CTX = "ctx"; private static HashMap initParams; /** *Start-Methode dieser Anwendung
* * @param args Kommandozeilenparameter */ public static void main(String[] args) { initParams = new HashMap(); for (String arg : args) { String[] argParts = arg.split("="); initParams.put(argParts[0], argParts[1]); } String portStr = getInitParameter(IP_PORT); if (portStr != null) { Server server = new Server(Integer.parseInt(portStr)); try { String ctxName = getInitParameter(IP_CTX); if (ctxName != null) { server.setContextName(ctxName); server.start(); } else { logger.severe("Der Parameter " + IP_CTX + " muss angegeben werden."); } } catch (IOException ex) { Logger.getLogger(App.class.getName()).log(Level.SEVERE, null, ex); } } else { logger.severe("Der Parameter " + IP_PORT + " muss angegeben werden."); } } /** * Diese Anwendung stoppen */ public static void stop() { System.exit(0); } /** * Einen Kommandozeilenparameter ermitteln * * @param pname Names des Parameters * @return Inhalt des Parameters oder null, wenn der Parameter nicht gefunden * wurde */ public static String getInitParameter(String pname) { String param = null; Object o = initParams.get(pname); if (o != null) { param = o.toString(); } return param; } }