contrib
Class NanoHTTPD

java.lang.Object
  extended by contrib.NanoHTTPD
Direct Known Subclasses:
Moconti

public class NanoHTTPD
extends java.lang.Object

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

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

Features & limitations:

Raffi-Modifications:

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_NOT_MODIFIED
          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
 
Constructor Summary
NanoHTTPD(int port)
          Inits an HTTP server to given port.
NanoHTTPD(int port, boolean listen)
          Inits an HTTP server to given port.
 
Method Summary
 void listen()
          Starts the HTTP server listening on the port it was initialized with
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_NOT_MODIFIED

public static final java.lang.String HTTP_NOT_MODIFIED
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
Constructor Detail

NanoHTTPD

public NanoHTTPD(int port)
          throws java.io.IOException
Inits an HTTP server to given port.

Throws an IOException if the socket is already in use

Throws:
java.io.IOException

NanoHTTPD

public NanoHTTPD(int port,
                 boolean listen)
          throws java.io.IOException
Inits an HTTP server to given port. Starts listening if value is set to true. 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.)

Returns:
HTTP response, see class Response for details

listen

public void listen()
            throws java.io.IOException
Starts the HTTP server listening on the port it was initialized with

Throws:
java.io.IOException

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.