From 38929aa1f4f4a017be4d2e93c32165b9e51f635d Mon Sep 17 00:00:00 2001
From: ulrich
Date: Tue, 21 Jul 2020 13:21:17 +0000
Subject: [PATCH] In Arbeit: PDF Theme

---
 src/de/uhilger/wbx/web/TNServlet.java |   93 +++++++++++++++++++++++++++++++++++++---------
 1 files changed, 75 insertions(+), 18 deletions(-)

diff --git a/src/de/uhilger/wbx/web/TNServlet.java b/src/de/uhilger/wbx/web/TNServlet.java
index 2d4e744..9e58fa2 100644
--- a/src/de/uhilger/wbx/web/TNServlet.java
+++ b/src/de/uhilger/wbx/web/TNServlet.java
@@ -17,14 +17,15 @@
  */
 package de.uhilger.wbx.web;
 
-import java.awt.Image;
 import java.io.File;
 import java.io.IOException;
-import java.io.OutputStream;
+import java.io.UnsupportedEncodingException;
+import java.net.URLDecoder;
 import java.util.logging.Logger;
 import javax.servlet.ServletException;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
+import net.coobird.thumbnailator.Thumbnails;
 import org.apache.catalina.servlets.DefaultServlet;
 
 /**
@@ -32,6 +33,8 @@
  * Miniaturansicht erzeugt werden, wie sie im Dateimanager 
  * der WebBox verwendet wird.
  * 
+ * Unterstuetzt werden die Varianten
+ * 120 (_tn), 240 (_kl), 500 (_dd), 700 (_mt), 1200 (_gr)
  */
 public class TNServlet extends DefaultServlet {
   
@@ -41,7 +44,12 @@
    * Diese String-Konstanten noetigenfalls in eine 
    * Konfigurationsdatei auslagern
    */
-  public static final String TN = "_tn";
+  public static final String TN = "_tn"; // 120
+  public static final String KL = "_kl"; // 240
+  public static final String SM = "_sm"; // 500
+  public static final String MT = "_mt"; // 700
+  public static final String GR = "_gr"; // 1200
+  
   public static final String JPG = ".jpg";
   public static final String JPEG = ".jpeg";
   public static final String PNG = ".png";
@@ -59,23 +67,72 @@
           throws ServletException, IOException {
     
     String uriStr = request.getRequestURI();
-    File imgfile = new File(uriStr);
+    String relname = uriStr.substring(request.getContextPath().length());
     
-    logger.fine("realpath of /: " + request.getServletContext().getRealPath("/"));
-    
-    logger.fine("imgfile: " + imgfile.getAbsolutePath());
-    
-    if(uriStr.contains(TN) && (uriStr.endsWith(JPG) || uriStr.endsWith(JPEG) || uriStr.endsWith(PNG))) {
-      /*
-      TODO: hier mit Hilfe der Klasse Bild eine Miniaturansicht erzeugen  
-      und in die Antwort schreiben
-      */      
-      //writeImageStream(Image image, int gr, String mimeType, response.getOutputStream());
-    } else {
-      super.doGet(request, response);
+    // --- Logausgabe Start
+    /*
+    File logurifile = new File(uriStr);
+    String loguriStr = uriStr.substring(request.getContextPath().length());
+    File logdir = new File(request.getServletContext().getRealPath("/"));
+    File imgfile = new File(logdir, loguriStr);    
+    StringBuffer buf = new StringBuffer();
+    buf.append("contextPath: ");
+    buf.append(request.getContextPath());
+    buf.append("\n");
+    buf.append("realpath of /: ");
+    buf.append(request.getServletContext().getRealPath("/"));
+    buf.append("\n");
+    buf.append("urifile: ");
+    buf.append(logurifile.getAbsolutePath());
+    buf.append("\n");
+    buf.append("imgfile: ");
+    buf.append(imgfile.getAbsolutePath());
+    logger.fine(buf.toString());
+    //System.out.println("TNServlet uri parts " + buf.toString());
+    */
+    // --- Logausgabe Ende
+        
+    if(uriStr.endsWith(JPG) || uriStr.endsWith(JPEG) || uriStr.endsWith(PNG)) {
+      File dir = new File(request.getServletContext().getRealPath("/"));
+      String suburiStr = uriStr.substring(request.getContextPath().length());
+      File imgfile = new File(dir, suburiStr);    
+      if(uriStr.contains(TN)) {
+        bildErzeugen(dir, relname, TN, 120, imgfile);
+      } else if(uriStr.contains(KL)) {
+        bildErzeugen(dir, relname, KL, 240, imgfile);
+      } else if(uriStr.contains(SM)) {
+        bildErzeugen(dir, relname, SM, 500, imgfile);
+      } else if(uriStr.contains(MT)) {
+        bildErzeugen(dir, relname, MT, 700, imgfile);
+      } else if(uriStr.contains(GR)) {
+        bildErzeugen(dir, relname, GR, 1200, imgfile);
+      }      
     }
-            
-    
+    super.doGet(request, response);
   }
   
+  private void bildErzeugen(File dir, String relname, String indicator, int gr, File tnfile) 
+          throws UnsupportedEncodingException, IOException {
+    //File dir = new File(request.getServletContext().getRealPath("/"));
+    // System.out.println("TNServlet dir: " + dir);
+    relname = relname.replace(indicator, "");
+    // System.out.println("TNServlet bildAusgeben relname: " + relname);
+    // relname: /test/img/IMG_0524.png
+    File imgfile = new File(dir, URLDecoder.decode(relname, "utf-8"));
+    
+    // 120, 240, 500, 700, 1200
+
+    /*Thumbnails.of(imgfile)
+            .size(gr, gr)
+            .keepAspectRatio(true)
+            .outputQuality(0.7)
+            .toOutputStream(response.getOutputStream());*/
+    if(imgfile.exists() && !tnfile.exists()) {
+      Thumbnails.of(imgfile)
+              .size(gr, gr)
+              .keepAspectRatio(true)
+              .outputQuality(0.7)
+              .toFile(tnfile);
+    }
+  }  
 }

--
Gitblit v1.9.3