annotate flys-client/src/main/java/de/intevation/flys/client/server/ProxyServlet.java @ 4419:e96f2a6e4c3e

Less debug output in GGInAFilter Remove unnecessary debug output in GGInAFilter
author Björn Ricks <bjoern.ricks@intevation.de>
date Tue, 06 Nov 2012 13:29:16 +0100
parents 92239b53823f
children
rev   line source
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
1 package de.intevation.flys.client.server;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
2
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
3 import java.io.InputStream;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
4 import java.io.IOException;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
5 import java.io.OutputStream;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
6 import java.util.Enumeration;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
7
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
8 import javax.servlet.ServletConfig;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
9 import javax.servlet.http.HttpServlet;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
10 import javax.servlet.http.HttpServletRequest;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
11 import javax.servlet.http.HttpServletResponse;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
12 import javax.servlet.http.HttpSession;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
13
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
14 import org.apache.http.Header;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
15 import org.apache.http.HttpEntity;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
16 import org.apache.http.HttpResponse;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
17 import org.apache.http.StatusLine;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
18 import org.apache.http.client.HttpClient;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
19 import org.apache.http.client.methods.HttpGet;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
20 import org.apache.http.impl.client.DefaultHttpClient;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
21
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
22 import org.apache.log4j.Logger;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
23
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
24 import de.intevation.flys.client.server.auth.User;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
25
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
26 /**
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
27 * Implements a Proxy for HTTP Requests
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
28 */
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
29 public class ProxyServlet
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
30 extends HttpServlet
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
31 {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
32 private static Logger logger = Logger.getLogger(ProxyServlet.class);
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
33 private String remoteurl;
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
34
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
35 @Override
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
36 public void init(ServletConfig config) {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
37 this.remoteurl = config.getInitParameter("remoteurl");
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
38 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
39
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
40 @Override
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
41 public void doPost(HttpServletRequest req, HttpServletResponse resp) {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
42 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
43
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
44 @Override
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
45 public void doGet(HttpServletRequest req, HttpServletResponse resp)
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
46 throws IOException {
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
47 HttpClient httpclient = new DefaultHttpClient();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
48
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
49 String requesturi = req.getRequestURI();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
50 String query = req.getQueryString();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
51
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
52 HttpGet httpget = new HttpGet(this.remoteurl + "?" + query);
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
53
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
54 boolean debug = logger.isDebugEnabled();
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
55
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
56 for (Enumeration e = req.getHeaderNames(); e.hasMoreElements();) {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
57 String name = (String)e.nextElement();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
58 for (Enumeration f = req.getHeaders(name); f.hasMoreElements();) {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
59 String value = (String)f.nextElement();
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
60 if (debug) {
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
61 logger.debug(
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
62 "Adding request header " + name + " : " + value);
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
63 }
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
64 httpget.addHeader(name, value);
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
65 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
66 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
67
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
68 HttpResponse response = httpclient.execute(httpget);
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
69
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
70 StatusLine statusline = response.getStatusLine();
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
71 if (debug) {
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
72 logger.debug("Response statuscode " + statusline.getStatusCode());
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
73 }
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
74 resp.setStatus(statusline.getStatusCode());
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
75
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
76 Header[] headers = response.getAllHeaders();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
77 for(Header header : headers) {
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
78 if (debug) {
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
79 logger.debug(
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
80 "Adding response header " + header.getName() +
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
81 " : " + header.getValue());
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
82 }
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
83 resp.setHeader(header.getName(), header.getValue());
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
84 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
85
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
86 HttpEntity entity = response.getEntity();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
87 if (entity != null) {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
88 InputStream instream = entity.getContent();
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
89 byte [] buf = new byte[4096];
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
90 try {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
91 OutputStream outstream = resp.getOutputStream();
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
92 try {
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
93 int read;
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
94 while ((read = instream.read(buf)) >= 0) {
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
95 outstream.write(buf, 0, read);
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
96 }
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
97 outstream.flush();
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
98 }
3498
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
99 finally {
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
100 outstream.close();
92239b53823f ProxyServlet: Use block instead of byte wise copy.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 3497
diff changeset
101 }
3497
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
102 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
103 finally {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
104 instream.close();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
105 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
106 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
107 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
108
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
109 private User getUser(HttpServletRequest req) {
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
110 HttpSession session = req.getSession();
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
111 return (User)session.getAttribute("user");
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
112 }
88feb3347aa5 Implement a ProxyServlet
Bjoern Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
113 }

http://dive4elements.wald.intevation.org