fi.iki.elonen.nanohttpd
Class NanoHTTPD

java.lang.Object
  extended by fi.iki.elonen.nanohttpd.NanoHTTPD
Direct Known Subclasses:
MediaHTTPD

public class NanoHTTPD
extends java.lang.Object

A simple, tiny, nicely embeddable HTTP 1.0 server in Java

NanoHTTPD version 1.02, Copyright © 2001,2005 Jarno Elonen (elonen@iki.fi, http://iki.fi/elonen/)

Features & limitations:

Ways to use:

See the end of the source file for distribution license (Modified BSD licence)


Nested Class Summary
 class NanoHTTPD.Response
          HTTP response.
 
Field Summary
static java.lang.String HTTP_BADREQUEST
          Some HTTP response status codes
static java.lang.String HTTP_FORBIDDEN
          Some HTTP response status codes
static java.lang.String HTTP_INTERNALERROR
          Some HTTP response status codes
static java.lang.String HTTP_NOTFOUND
          Some HTTP response status codes
static java.lang.String HTTP_NOTIMPLEMENTED
          Some HTTP response status codes
static java.lang.String HTTP_OK
          Some HTTP response status codes
static java.lang.String HTTP_REDIRECT
          Some HTTP response status codes
static java.lang.String MIME_DEFAULT_BINARY
          Common mime types for dynamic content
static java.lang.String MIME_HTML
          Common mime types for dynamic content
static java.lang.String MIME_PLAINTEXT
          Common mime types for dynamic content
protected  java.io.File myFileDir
           
 
Constructor Summary
NanoHTTPD(int port)
          Starts a HTTP server to given port.
 
Method Summary
static void main(java.lang.String[] args)
          Starts as a standalone file server and waits for Enter.
 NanoHTTPD.Response serve(java.lang.String uri, java.lang.String method, java.util.Properties header, java.util.Properties parms)
          Override this to customize the server.
 NanoHTTPD.Response serveFile(java.lang.String uri, java.util.Properties header, java.io.File homeDir, boolean allowDirectoryListing)
          Serves file from homeDir and its' subdirectories (only).
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

HTTP_OK

public static final java.lang.String HTTP_OK
Some HTTP response status codes

See Also:
Constant Field Values

HTTP_REDIRECT

public static final java.lang.String HTTP_REDIRECT
Some HTTP response status codes

See Also:
Constant Field Values

HTTP_FORBIDDEN

public static final java.lang.String HTTP_FORBIDDEN
Some HTTP response status codes

See Also:
Constant Field Values

HTTP_NOTFOUND

public static final java.lang.String HTTP_NOTFOUND
Some HTTP response status codes

See Also:
Constant Field Values

HTTP_BADREQUEST

public static final java.lang.String HTTP_BADREQUEST
Some HTTP response status codes

See Also:
Constant Field Values

HTTP_INTERNALERROR

public static final java.lang.String HTTP_INTERNALERROR
Some HTTP response status codes

See Also:
Constant Field Values

HTTP_NOTIMPLEMENTED

public static final java.lang.String HTTP_NOTIMPLEMENTED
Some HTTP response status codes

See Also:
Constant Field Values

MIME_PLAINTEXT

public static final java.lang.String MIME_PLAINTEXT
Common mime types for dynamic content

See Also:
Constant Field Values

MIME_HTML

public static final java.lang.String MIME_HTML
Common mime types for dynamic content

See Also:
Constant Field Values

MIME_DEFAULT_BINARY

public static final java.lang.String MIME_DEFAULT_BINARY
Common mime types for dynamic content

See Also:
Constant Field Values

myFileDir

protected java.io.File myFileDir
Constructor Detail

NanoHTTPD

public NanoHTTPD(int port)
          throws java.io.IOException
Starts a HTTP server to given port.

Throws an IOException if the socket is already in use

Throws:
java.io.IOException
Method Detail

serve

public NanoHTTPD.Response serve(java.lang.String uri,
                                java.lang.String method,
                                java.util.Properties header,
                                java.util.Properties parms)
Override this to customize the server.

(By default, this delegates to serveFile() and allows directory listing.)

Parameters:
uri - Percent-decoded URI without parameters, for example "/index.cgi"
method - "GET", "POST" etc.
parms - Parsed, percent decoded parameters from URI and, in case of POST, data.
header - Header entries, percent decoded
Returns:
HTTP response, see class Response for details

main

public static void main(java.lang.String[] args)
Starts as a standalone file server and waits for Enter.


serveFile

public NanoHTTPD.Response serveFile(java.lang.String uri,
                                    java.util.Properties header,
                                    java.io.File homeDir,
                                    boolean allowDirectoryListing)
Serves file from homeDir and its' subdirectories (only). Uses only URI, ignores all headers and HTTP parameters.