aboutsummaryrefslogtreecommitdiff
path: root/fileupload/src
diff options
context:
space:
mode:
authorVictor Nikiforov <victor.nike@gmail.com>2015-08-10 11:46:31 +0300
committerVictor Nikiforov <victor.nike@gmail.com>2015-08-10 12:00:05 +0300
commitf22e738c41798cac1dc891a29a960f03a2e4336c (patch)
tree531e8f72302b857817ad3693af31076e87439808 /fileupload/src
parent9e659197ebe52fa61801c20b913d666087f98eb4 (diff)
downloadnanohttpd-f22e738c41798cac1dc891a29a960f03a2e4336c.tar.gz
Issue #216 - Integration with apache.commons.fileupload enhancement
Diffstat (limited to 'fileupload/src')
-rw-r--r--fileupload/src/main/java/fi/iki/elonen/NanoFileUpload.java43
-rw-r--r--fileupload/src/main/java/fi/iki/elonen/NanoHttpdContext.java51
2 files changed, 94 insertions, 0 deletions
diff --git a/fileupload/src/main/java/fi/iki/elonen/NanoFileUpload.java b/fileupload/src/main/java/fi/iki/elonen/NanoFileUpload.java
new file mode 100644
index 0000000..ec2e4e8
--- /dev/null
+++ b/fileupload/src/main/java/fi/iki/elonen/NanoFileUpload.java
@@ -0,0 +1,43 @@
+package fi.iki.elonen;
+
+import org.apache.commons.fileupload.FileItem;
+import org.apache.commons.fileupload.FileItemFactory;
+import org.apache.commons.fileupload.FileItemIterator;
+import org.apache.commons.fileupload.FileUpload;
+import org.apache.commons.fileupload.FileUploadBase;
+import org.apache.commons.fileupload.FileUploadException;
+
+import java.io.IOException;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * Created by victor on 7/30/15.
+ */
+public class NanoFileUpload extends FileUpload {
+ private static final String POST_METHOD = "POST";
+
+ public static final boolean isMultipartContent(NanoHTTPD.IHTTPSession session) {
+ return !"POST".equalsIgnoreCase(session.getMethod().toString())?false: FileUploadBase.isMultipartContent(new NanoHttpdContext(session));
+ }
+
+ public NanoFileUpload() {
+ }
+
+ public NanoFileUpload(FileItemFactory fileItemFactory) {
+ super(fileItemFactory);
+ }
+
+ public List<FileItem> parseRequest(NanoHTTPD.IHTTPSession session) throws FileUploadException {
+ return this.parseRequest(new NanoHttpdContext(session));
+ }
+
+ public Map<String, List<FileItem>> parseParameterMap(NanoHTTPD.IHTTPSession session) throws FileUploadException {
+ return this.parseParameterMap(new NanoHttpdContext(session));
+ }
+
+ public FileItemIterator getItemIterator(NanoHTTPD.IHTTPSession session) throws FileUploadException, IOException {
+ return super.getItemIterator(new NanoHttpdContext(session));
+ }
+
+}
diff --git a/fileupload/src/main/java/fi/iki/elonen/NanoHttpdContext.java b/fileupload/src/main/java/fi/iki/elonen/NanoHttpdContext.java
new file mode 100644
index 0000000..1c4d89f
--- /dev/null
+++ b/fileupload/src/main/java/fi/iki/elonen/NanoHttpdContext.java
@@ -0,0 +1,51 @@
+package fi.iki.elonen;
+
+import org.apache.commons.fileupload.UploadContext;
+
+import java.io.IOException;
+import java.io.InputStream;
+
+/**
+ * Created by victor on 7/30/15.
+ */
+public class NanoHttpdContext implements UploadContext {
+
+ private NanoHTTPD.IHTTPSession session;
+
+ public NanoHttpdContext(NanoHTTPD.IHTTPSession session) {
+ this.session = session;
+ }
+
+ @Override
+ public long contentLength() {
+ long size;
+ try {
+ String cl1 = session.getHeaders().get("content-length");
+ size = Long.parseLong(cl1);
+ } catch (NumberFormatException var4) {
+ size = -1L;
+ }
+
+ return size;
+ }
+
+ @Override
+ public String getCharacterEncoding() {
+ return "UTF-8";
+ }
+
+ @Override
+ public String getContentType() {
+ return this.session.getHeaders().get("content-type");
+ }
+
+ @Override
+ public int getContentLength() {
+ return (int)contentLength();
+ }
+
+ @Override
+ public InputStream getInputStream() throws IOException {
+ return session.getInputStream();
+ }
+}