Ein minimalistischer HTTP-Server
ulrich
2021-03-27 6d3836e41493f89c5b8700cca34111319e9fa41a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*
  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 <https://www.gnu.org/licenses/>.
 */
package de.uhilger.minsrv;
 
import java.io.IOException;
import java.util.HashMap;
import java.util.logging.Level;
import java.util.logging.Logger;
 
/**
 * <p>Die Hauptklasse des mini-server</p>
 *
 * <p>Folgende Kommandozeilenparameter werden verarbeitet </p>
 * 
 * <p>ctx - Kontext des Servers <br>
 * www-data - lokales Datenverzeichnis <br>
 * port - Port</p>>
 *
 * <p>Beispiel: <code>java -jar mini-server.jar ctx="srv" www-data="/home/fred/www"
 * port=9090</code></p>
 *
 * <p>Startet den Server auf http://localhost:9090/srv und liefert Inhalte aus
 * dem Verzeichnis <code>/home/fred/www</code> 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.</p>
 * 
 * <p>Mit http://localhost:9090/srv/server/stop werden Server und App 
 * beendet.</p>
 *
 * @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;
 
  /**
   * <p>Start-Methode dieser Anwendung</p>
   *
   * @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;
  }
}