WebBox Klassenbibliothek
ulrich
2017-12-28 bc9f6a12a3bd068f1b9f781539c41d8d86b7e409
Generischen Filtermechanismus zur Veraenderung von Server-Antworten hinzugefuegt.
2 files modified
4 files added
3 files deleted
494 ■■■■■ changed files
src/de/uhilger/wbx/web/CustomResponseWrapper.java 70 ●●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/FilterServletOutputStream.java 49 ●●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/GenericResponseWrapper.java 69 ●●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/MarkdownServlet.java 45 ●●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/MyGenericFilter.java 48 ●●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/PrePostFilter.java 71 ●●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/ViewServlet.java 44 ●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/WbxServlet.java 94 ●●●●● patch | view | raw | blame | history
src/logging.properties 4 ●●●● patch | view | raw | blame | history
src/de/uhilger/wbx/web/CustomResponseWrapper.java
File was deleted
src/de/uhilger/wbx/web/FilterServletOutputStream.java
New file
@@ -0,0 +1,49 @@
/*
    WebBox - Dein Server.
    Copyright (C) 2017 Ulrich Hilger, http://uhilger.de
    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU Affero General Public License as
    published by the Free Software Foundation, either version 3 of the
    License, or (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Affero General Public License for more details.
    You should have received a copy of the GNU Affero General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package de.uhilger.wbx.web;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import javax.servlet.ServletOutputStream;
/**
 *
 * @author ulrich
 */
public class FilterServletOutputStream extends ServletOutputStream {
  private DataOutputStream stream;
  public FilterServletOutputStream(OutputStream output) {
    stream = new DataOutputStream(output);
  }
  public void write(int b) throws IOException  {
    stream.write(b);
  }
  public void write(byte[] b) throws IOException  {
    stream.write(b);
  }
  public void write(byte[] b, int off, int len) throws IOException  {
    stream.write(b,off,len);
  }
}
src/de/uhilger/wbx/web/GenericResponseWrapper.java
New file
@@ -0,0 +1,69 @@
/*
    WebBox - Dein Server.
    Copyright (C) 2017 Ulrich Hilger, http://uhilger.de
    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU Affero General Public License as
    published by the Free Software Foundation, either version 3 of the
    License, or (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Affero General Public License for more details.
    You should have received a copy of the GNU Affero General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package de.uhilger.wbx.web;
import java.io.ByteArrayOutputStream;
import java.io.PrintWriter;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
/**
 *
 * @author ulrich
 */
public class GenericResponseWrapper extends HttpServletResponseWrapper {
  private ByteArrayOutputStream output;
  private int contentLength;
  private String contentType;
  public GenericResponseWrapper(HttpServletResponse response) {
    super(response);
    output=new ByteArrayOutputStream();
  }
  public byte[] getData() {
    return output.toByteArray();
  }
  public ServletOutputStream getOutputStream() {
    return new FilterServletOutputStream(output);
  }
  public PrintWriter getWriter() {
    return new PrintWriter(getOutputStream(),true);
  }
  public void setContentLength(int length) {
    this.contentLength = length;
    super.setContentLength(length);
  }
  public int getContentLength() {
    return contentLength;
  }
  public void setContentType(String type) {
    this.contentType = type;
    super.setContentType(type);
  }
  public String getContentType() {
    return contentType;
  }
}
src/de/uhilger/wbx/web/MarkdownServlet.java
File was deleted
src/de/uhilger/wbx/web/MyGenericFilter.java
New file
@@ -0,0 +1,48 @@
/*
    WebBox - Dein Server.
    Copyright (C) 2017 Ulrich Hilger, http://uhilger.de
    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU Affero General Public License as
    published by the Free Software Foundation, either version 3 of the
    License, or (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Affero General Public License for more details.
    You should have received a copy of the GNU Affero General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package de.uhilger.wbx.web;
import java.util.logging.Logger;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
/**
 *
 * @author ulrich
 */
public class MyGenericFilter implements javax.servlet.Filter {
  private static final Logger logger = Logger.getLogger(MyGenericFilter.class.getName());
  public FilterConfig filterConfig;
  public void doFilter(final ServletRequest request,
                       final ServletResponse response,
                       FilterChain chain)
      throws java.io.IOException, javax.servlet.ServletException {
    chain.doFilter(request,response);
  }
  public void init(final FilterConfig filterConfig) {
    this.filterConfig = filterConfig;
    logger.info("   initialisiert.");
  }
  public void destroy() {
  }
}
src/de/uhilger/wbx/web/PrePostFilter.java
New file
@@ -0,0 +1,71 @@
/*
    WebBox - Dein Server.
    Copyright (C) 2017 Ulrich Hilger, http://uhilger.de
    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU Affero General Public License as
    published by the Free Software Foundation, either version 3 of the
    License, or (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Affero General Public License for more details.
    You should have received a copy of the GNU Affero General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package de.uhilger.wbx.web;
import java.io.IOException;
import java.io.OutputStream;
import java.util.logging.Logger;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
 * Dieser Filter ist dem Beispiel auf
 * http://otndnld.oracle.co.jp/document/products/as10g/101300/B25221_03/web.1013/b14426/filters.htm#BCFIAAAH
 * entnommen und kann zum Testen von Filter-Konfigurationen oder als Ausgangsbasis
 * fuer komplexere Filter-Funktionen verwendet werden.
 *
 * Das Beispiel umschliesst eine beliebige Antwort vom Server mit
 * <HR>PRE</HR> <HR>POST</HR>
 *
 * @author ulrich
 */
public class PrePostFilter extends MyGenericFilter {
  private static final Logger logger = Logger.getLogger(PrePostFilter.class.getName());
  public void doFilter(final ServletRequest request,
                       final ServletResponse response,
                       FilterChain chain)
       throws IOException, ServletException {
  HttpServletRequest hr = (HttpServletRequest) request;
  logger.info("requestURL: " + hr.getRequestURL().toString());
  logger.info("ContextPath: " + hr.getContextPath());
  logger.info("ServletPath: " + hr.getServletPath());
  logger.info("PathInfo: " + hr.getPathInfo());
  OutputStream out = response.getOutputStream();
  out.write(new String("<HR>PRE<HR>").getBytes());
  GenericResponseWrapper wrapper =
         new GenericResponseWrapper((HttpServletResponse) response);
  chain.doFilter(request,wrapper);
  out.write(wrapper.getData());
  out.write(new String("<HR>POST<HR>").getBytes());
  out.close();
  }
  /*
  MarkdownProcessor p = new MarkdownProcessor();
    response.getWriter().write(p.markdown(responseContent));
  */
}
src/de/uhilger/wbx/web/ViewServlet.java
@@ -18,11 +18,14 @@
package de.uhilger.wbx.web;
import java.io.IOException;
import java.security.Principal;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.catalina.servlets.DefaultServlet;
/**
 * Das ViewServlet f&uuml;gt dem DefaultServlet von Tomcat 
@@ -33,12 +36,13 @@
 * 
 * TODO: Stylesheets dynamisch einbinden
 */
public class ViewServlet extends WbxServlet {
public class ViewServlet extends DefaultServlet {
  
  private static final Logger logger = Logger.getLogger(ViewServlet.class.getName());
  //private static final String HOME_CTX = "/home";
  private static final String HOME_CTX = "/home";
  protected void seiteAusgeben(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
  private void seiteAusgeben(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
    ServletOutputStream out = response.getOutputStream();
    printHeader(out);
    super.doGet(request, response);
@@ -60,8 +64,35 @@
    out.print("</body></html>");
  }
  
  /*
  private String getUrlUser(HttpServletRequest request, String userName) throws IOException {
  /**
   * Handles the HTTP <code>GET</code> method.
   *
   * @param request servlet request
   * @param response servlet response
   * @throws ServletException if a servlet-specific error occurs
   * @throws IOException if an I/O error occurs
   */
  @Override
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException  {
    String contextPath = request.getContextPath();
    if(HOME_CTX.equals(contextPath)) {
      String userName = getUserName(request);
      if (userName != null) {
        String urlUser = getUrlUser(request, userName);
        if(userName.equals(urlUser)) {
          seiteAusgeben(request, response);
        } else {
          logger.fine("Wrong user.");
        }
      } else {
        logger.fine("Missing login.");
      }
    } else {
      seiteAusgeben(request, response);
    }
  }
  protected String getUrlUser(HttpServletRequest request, String userName) {
    String result = "";
    String requestUrlStr = request.getRequestURL().toString();
    String contextPath = request.getContextPath();
@@ -79,7 +110,7 @@
    return result;
  }
  
  private String getUserName(HttpServletRequest hr) {
  protected String getUserName(HttpServletRequest hr) {
    String userName = null;
    Object p = hr.getUserPrincipal();
    if (p instanceof Principal) {
@@ -87,7 +118,6 @@
    }
    return userName;
  }
  */
  /**
   * Returns a short description of the servlet.
src/de/uhilger/wbx/web/WbxServlet.java
File was deleted
src/logging.properties
@@ -27,7 +27,7 @@
# Note that the ConsoleHandler also has a separate level
# setting to limit messages printed to the console.
# .level= FINE
.level = OFF
.level = NONE
############################################################
# Handler specific properties.
@@ -65,4 +65,4 @@
# messages:
# com.xyz.foo.level = SEVERE
de.uhilger.wbx.handlers = java.util.logging.ConsoleHandler
de.uhilger.wbx.level = FINER
de.uhilger.wbx.level = INFO