From ee6a3e9057bff6e30e6deff43100bcf2bf9bfba5 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Sat, 27 Mar 2021 14:32:52 +0000
Subject: [PATCH] Anpassungen am FielHandler, Stop-Ablauf verfeinert
---
src/de/uhilger/minsrv/handler/FileHandler.java | 13 +++++++++++--
1 files changed, 11 insertions(+), 2 deletions(-)
diff --git a/src/de/uhilger/minsrv/handler/FileHandler.java b/src/de/uhilger/minsrv/handler/FileHandler.java
index 45e31c2..570e4e2 100644
--- a/src/de/uhilger/minsrv/handler/FileHandler.java
+++ b/src/de/uhilger/minsrv/handler/FileHandler.java
@@ -57,6 +57,7 @@
public static final String ACCEPT_RANGES_HEADER = "Accept-Ranges";
public static final String LAST_MODIFIED_DATE_HEADER = "Last-Modified";
public static final String CONTENT_TYPE = "Content-Type";
+ public static final String CONTENT_LENGTH = "Content-Length";
/* Statuscodes */
public static final int SC_OK = 200;
@@ -110,7 +111,7 @@
if (headers.containsKey(RANGE_HEADER)) {
serveFileParts(e, new File(fileBase, fName));
} else {
- if (fName.endsWith(Server.STR_SLASH)) {
+ if (fName.length() < 1 || fName.endsWith(Server.STR_SLASH)) {
fName += WELCOME_FILE;
}
serveFile(e, new File(fileBase, fName));
@@ -118,6 +119,13 @@
}
}
+ /**
+ * Den Namen der gewünschten Datei aus der HTTP-Anfrage ermitteln
+ *
+ * @param e das Objekt mit Methoden zur Untersuchung der Anfrage sowie zum
+ * Anfertigen und Senden der Antwort
+ * @return Name der gewünschten Datei
+ */
protected String getFileName(HttpExchange e) {
String ctxPath = e.getHttpContext().getPath();
String uriPath = e.getRequestURI().getPath();
@@ -136,6 +144,7 @@
protected void serveFile(HttpExchange e, File file) throws IOException {
if (file.exists()) {
setHeaders(e, file);
+ e.getResponseHeaders().set(CONTENT_LENGTH, Long.toString(file.length()));
e.sendResponseHeaders(SC_OK, file.length());
if(HTTP_GET.equalsIgnoreCase(e.getRequestMethod())) {
InputStream in = new FileInputStream(file);
@@ -354,7 +363,7 @@
* aus Bytes, der sich aus den Bytepositionen des Beginns und Endes
* des Bereiches ergibt.
*/
- class Range {
+ public class Range {
private long start;
private long end;
--
Gitblit v1.9.3