Mercurial Hosting > luan
view src/goodjava/webserver/examples/Example.java @ 1426:94a6a209d4e2
fix
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Sun, 24 Nov 2019 16:38:06 -0700 |
parents | 27efb1fcbcb5 |
children | 219f2b937f2b |
line wrap: on
line source
package goodjava.webserver.examples; import java.io.Writer; import java.io.OutputStreamWriter; import java.io.IOException; import java.util.Map; import java.util.HashMap; import org.apache.log4j.EnhancedPatternLayout; import org.apache.log4j.ConsoleAppender; import org.apache.log4j.Logger; import goodjava.webserver.Handler; import goodjava.webserver.Request; import goodjava.webserver.Response; import goodjava.webserver.ResponseOutputStream; import goodjava.webserver.Server; import goodjava.webserver.handlers.MapHandler; import goodjava.webserver.handlers.SafeHandler; import goodjava.webserver.handlers.LogHandler; import goodjava.webserver.handlers.FileHandler; import goodjava.webserver.handlers.DirHandler; import goodjava.webserver.handlers.ListHandler; import goodjava.webserver.handlers.ContentTypeHandler; public class Example implements Handler { public Response handle(Request request) { Response response = new Response(); response.headers.put( "content-type", "text/plain; charset=utf-8" ); try { Writer writer = new OutputStreamWriter( new ResponseOutputStream(response) ); writer.write("Hello World\n"); writer.close(); } catch(IOException e) { throw new RuntimeException("shouldn't happen",e); } return response; } public static void simple() throws IOException { Handler handler = new Example(); new Server(8080,handler).start(); } public static void fancy() throws IOException { Map<String,Handler> map = new HashMap<String,Handler>(); map.put( "/hello", new Example() ); map.put( "/headers", new Headers() ); map.put( "/params", new Params() ); map.put( "/cookies", new Cookies() ); Handler mapHandler = new MapHandler(map); FileHandler fileHandler = new FileHandler(); Handler dirHandler = new DirHandler(fileHandler); Handler handler = new ListHandler( mapHandler, fileHandler, dirHandler ); handler = new ContentTypeHandler(handler); handler = new SafeHandler(handler); handler = new LogHandler(handler); new Server(8080,handler).start(); } public static void initLogging() { // Logger.getRootLogger().setLevel(Level.INFO); EnhancedPatternLayout layout = new EnhancedPatternLayout("%d{HH:mm:ss} %-5p %c - %m%n"); ConsoleAppender appender = new ConsoleAppender(layout,"System.err"); Logger.getRootLogger().addAppender(appender); } public static void main(String[] args) throws Exception { initLogging(); fancy(); } }