aboutsummaryrefslogtreecommitdiff
path: root/README.md
diff options
context:
space:
mode:
authorPaul Hawke <paul.hawke@gmail.com>2013-12-12 06:06:25 -0600
committerPaul Hawke <paul.hawke@gmail.com>2013-12-12 06:06:25 -0600
commitef3be58ec24d3e155c8036f8806dba7172f61d0c (patch)
treee829db9643634d8320e5cbb3282ac2197759bbbe /README.md
parent68394ef81a80928d25e584475be59a2e937a5ae0 (diff)
downloadnanohttpd-ef3be58ec24d3e155c8036f8806dba7172f61d0c.tar.gz
Tests and documentation cleanup.
Diffstat (limited to 'README.md')
-rw-r--r--README.md76
1 files changed, 63 insertions, 13 deletions
diff --git a/README.md b/README.md
index ff92ddd..6c04773 100644
--- a/README.md
+++ b/README.md
@@ -77,33 +77,83 @@ Secondly, you can run the standalone *NanoHttpd Webserver*.
Or, create your own class that extends `NanoHTTPD` and overrides one of the two flavors of the `serve()` method. For example:
```java
+package fi.iki.elonen.debug;
+
+import fi.iki.elonen.NanoHTTPD;
+import fi.iki.elonen.ServerRunner;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
public class DebugServer extends NanoHTTPD {
- /**
- * Constructs an HTTP server on given port.
- */
public DebugServer() {
super(8080);
}
- @Override
- public Response serve(String uri, Method method, Map<String, String> header, Map<String, String> parms, Map<String, String> files) {
+ public static void main(String[] args) {
+ ServerRunner.run(DebugServer.class);
+ }
+
+ @Override public Response serve(IHTTPSession session) {
+ Map<String, List<String>> decodedQueryParameters =
+ decodeParameters(session.getQueryParameterString());
+
StringBuilder sb = new StringBuilder();
sb.append("<html>");
sb.append("<head><title>Debug Server</title></head>");
sb.append("<body>");
- sb.append("<h1>Response</h1>");
- sb.append("<p><blockquote><b>URI -</b> ").append(uri).append("<br />");
- sb.append("<b>Method -</b> ").append(method).append("</blockquote></p>");
- sb.append("<h3>Headers</h3><p><blockquote>").append(header).append("</blockquote></p>");
- sb.append("<h3>Parms</h3><p><blockquote>").append(parms).append("</blockquote></p>");
- sb.append("<h3>Files</h3><p><blockquote>").append(files).append("</blockquote></p>");
+ sb.append("<h1>Debug Server</h1>");
+
+ sb.append("<p><blockquote><b>URI</b> = ").append(
+ String.valueOf(session.getUri())).append("<br />");
+
+ sb.append("<b>Method</b> = ").append(
+ String.valueOf(session.getMethod())).append("</blockquote></p>");
+
+ sb.append("<h3>Headers</h3><p><blockquote>").
+ append(toString(session.getHeaders())).append("</blockquote></p>");
+
+ sb.append("<h3>Parms</h3><p><blockquote>").
+ append(toString(session.getParms())).append("</blockquote></p>");
+
+ sb.append("<h3>Parms (multi values?)</h3><p><blockquote>").
+ append(toString(decodedQueryParameters)).append("</blockquote></p>");
+
+ try {
+ Map<String, String> files = new HashMap<String, String>();
+ session.parseBody(files);
+ sb.append("<h3>Files</h3><p><blockquote>").
+ append(toString(files)).append("</blockquote></p>");
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+
sb.append("</body>");
sb.append("</html>");
return new Response(sb.toString());
}
- public static void main(String[] args) {
- ServerRunner.run(DebugServer.class);
+ private String toString(Map<String, ? extends Object> map) {
+ if (map.size() == 0) {
+ return "";
+ }
+ return unsortedList(map);
+ }
+
+ private String unsortedList(Map<String, ? extends Object> map) {
+ StringBuilder sb = new StringBuilder();
+ sb.append("<ul>");
+ for (Map.Entry entry : map.entrySet()) {
+ listItem(sb, entry);
+ }
+ sb.append("</ul>");
+ return sb.toString();
+ }
+
+ private void listItem(StringBuilder sb, Map.Entry entry) {
+ sb.append("<li><code><b>").append(entry.getKey()).
+ append("</b> = ").append(entry.getValue()).append("</code></li>");
}
}
```