diff options
author | Paul Hawke <paul.hawke@gmail.com> | 2013-12-12 06:06:25 -0600 |
---|---|---|
committer | Paul Hawke <paul.hawke@gmail.com> | 2013-12-12 06:06:25 -0600 |
commit | ef3be58ec24d3e155c8036f8806dba7172f61d0c (patch) | |
tree | e829db9643634d8320e5cbb3282ac2197759bbbe /README.md | |
parent | 68394ef81a80928d25e584475be59a2e937a5ae0 (diff) | |
download | nanohttpd-ef3be58ec24d3e155c8036f8806dba7172f61d0c.tar.gz |
Tests and documentation cleanup.
Diffstat (limited to 'README.md')
-rw-r--r-- | README.md | 76 |
1 files changed, 63 insertions, 13 deletions
@@ -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>"); } } ``` |