Ein minimalistischer HTTP-Server
ulrich
2021-03-26 d0bb217f9fd72ff981c1e96aac9d7d87006d7736
src/de/uhilger/minsrv/App.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;
import java.io.IOException;
@@ -25,75 +24,84 @@
/**
 * Die Hauptklasse des mini-server
 *
 *
 * @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;
  private static HashMap initParams;
  /**
   * Start-Methode dieser Anwendung
   *
   * 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.
   *
   *
   * 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.
   *
   * @param args Kommandozeilenparameter
   */
  public static void main(String[] args) {
    initParams = new HashMap();
    for(String arg: args) {
    for (String arg : args) {
      String[] argParts = arg.split("=");
      initParams.put(argParts[0], argParts[1]);
    }
    Server server = new Server(Integer.parseInt(getInitParameter(IP_PORT)));
    try {
      server.start();
    } catch (IOException ex) {
      Logger.getLogger(App.class.getName()).log(Level.SEVERE, null, ex);
    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
   * @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) {
    if (o != null) {
      param = o.toString();
    }
    return param;
  }
  }
}