diff options
| author | RblSb <msrblsb@gmail.com> | 2025-03-02 10:09:26 +0300 |
|---|---|---|
| committer | RblSb <msrblsb@gmail.com> | 2025-03-03 00:51:38 +0300 |
| commit | aed0d8ed6865a3e966fa866af4b99f5d4b4d33eb (patch) | |
| tree | c6c0274dc824f15855af4534747e5d36433e42a0 /src/server | |
| parent | 3b22ce9b59e1e549dddbba99b90b87a1dc1fcf87 (diff) | |
Improve upload filename encoding
Diffstat (limited to 'src/server')
| -rw-r--r-- | src/server/HttpServer.hx | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/src/server/HttpServer.hx b/src/server/HttpServer.hx index 8f0b56e..4734815 100644 --- a/src/server/HttpServer.hx +++ b/src/server/HttpServer.hx @@ -113,6 +113,8 @@ class HttpServer { if (hasCustomRes) { final path = getPath(customDir, url); if (Fs.existsSync(path)) filePath = path; + final ext = Path.extension(filePath).toLowerCase(); + res.setHeader("content-type", getMimeType(ext)); } if (isMediaExtension(ext)) { @@ -133,7 +135,9 @@ class HttpServer { } function uploadFileLastChunk(req:IncomingMessage, res:ServerResponse) { - final name = cache.getFreeFileName(req.headers["content-name"]); + var fileName = try decodeURIComponent(req.headers["content-name"]) catch (e) ""; + if (fileName.trim().length == 0) fileName = null; + final name = cache.getFreeFileName(fileName); final filePath = cache.getFilePath(name); final body:Array<Any> = []; req.on("data", chunk -> body.push(chunk)); @@ -152,8 +156,9 @@ class HttpServer { } function uploadFile(req:IncomingMessage, res:ServerResponse) { - final name = cache.getFreeFileName(req.headers["content-name"]); - final clientName = req.headers["client-name"]; + var fileName = try decodeURIComponent(req.headers["content-name"]) catch (e) ""; + if (fileName.trim().length == 0) fileName = null; + final name = cache.getFreeFileName(fileName); final filePath = cache.getFilePath(name); final size = Std.parseInt(req.headers["content-length"]) ?? return; @@ -210,8 +215,7 @@ class HttpServer { } function getPath(dir:String, url:URL):String { - var filePath = dir + url.pathname; - filePath = filePath.urlDecode(); + final filePath = dir.urlDecode() + decodeURIComponent(url.pathname); if (!FileSystem.isDirectory(filePath)) return filePath; return Path.addTrailingSlash(filePath) + "index.html"; } @@ -378,4 +382,8 @@ class HttpServer { inline function decodeURI(data:String):String { return js.Syntax.code("decodeURI({0})", data); } + + inline function decodeURIComponent(data:String):String { + return js.Syntax.code("decodeURIComponent({0})", data); + } } |
