changeset 1197:886e14903c1e

better Content-Type handling
author Franklin Schmidt <fschmidt@gmail.com>
date Tue, 27 Feb 2018 01:35:09 -0700 (2018-02-27)
parents 44491798e431
children 9d3835e88204
files src/luan/webserver/Connection.java src/luan/webserver/RequestParser.java
diffstat 2 files changed, 18 insertions(+), 11 deletions(-) [+]
line wrap: on
line diff
--- a/src/luan/webserver/Connection.java	Mon Feb 26 21:06:28 2018 -0700
+++ b/src/luan/webserver/Connection.java	Tue Feb 27 01:35:09 2018 -0700
@@ -60,7 +60,7 @@
 						}
 					}
 					String rawHead = new String(a,0,endOfHeader);
-//System.out.println(rawHead);
+					//System.out.println(rawHead);
 					request.rawHead = rawHead;
 					RequestParser parser = new RequestParser(request);
 					parser.parseHead();
@@ -79,21 +79,17 @@
 							size += n;
 						}
 						request.body = body;
-//System.out.println(new String(request.body));
+						//System.out.println(new String(request.body));
 					}
 	
 					String contentType = (String)request.headers.get("content-type");
 					if( contentType != null ) {
-						if( request.body == null ) {
-							logger.error("body is null\n"+request.rawHead);
+						if( "application/x-www-form-urlencoded".equals(contentType) ) {
+							parser.parseUrlencoded();
+						} else if( contentType.startsWith("multipart/form-data;") ) {
+							parser.parseMultipart();
 						} else {
-							if( "application/x-www-form-urlencoded".equals(contentType) ) {
-								parser.parseUrlencoded();
-							} else if( contentType.startsWith("multipart/form-data;") ) {
-								parser.parseMultipart();
-							} else {
-								logger.error("unknown content type: "+contentType);
-							}
+							logger.warn("unknown content type: "+contentType);
 						}
 					}
 				}
--- a/src/luan/webserver/RequestParser.java	Mon Feb 26 21:06:28 2018 -0700
+++ b/src/luan/webserver/RequestParser.java	Tue Feb 27 01:35:09 2018 -0700
@@ -2,11 +2,14 @@
 
 import java.util.List;
 import java.util.ArrayList;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import luan.lib.parser.Parser;
 import luan.lib.parser.ParseException;
 
 
 final class RequestParser {
+	private static final Logger logger = LoggerFactory.getLogger(Connection.class);
 	private final Request request;
 	private Parser parser;
 
@@ -15,6 +18,10 @@
 	}
 
 	void parseUrlencoded() throws ParseException {
+		if( request.body == null ) {
+			logger.error("body is null\n"+request.rawHead);
+			return;
+		}
 		this.parser = new Parser(Util.toString(request.body));
 		parseQuery();
 		require( parser.endOfInput() );
@@ -187,6 +194,10 @@
 	private static final String contentTypeStart = "multipart/form-data; boundary=";
 
 	void parseMultipart() throws ParseException {
+		if( request.body == null ) {
+			logger.error("body is null\n"+request.rawHead);
+			return;
+		}
 		String contentType = (String)request.headers.get("content-type");
 		if( !contentType.startsWith(contentTypeStart) )
 			throw new RuntimeException(contentType);