From 3e90dde80c4caf13f7507fa3a5e6a43c1f575e49 Mon Sep 17 00:00:00 2001 From: Alex Pogue Date: Wed, 16 Sep 2015 18:48:49 -0400 Subject: [PATCH] Add defensive code behind extraHeaders --- .../src/com/ibm/streamsx/inet/http/HTTPUtils.java | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/com.ibm.streamsx.inet/impl/java/src/com/ibm/streamsx/inet/http/HTTPUtils.java b/com.ibm.streamsx.inet/impl/java/src/com/ibm/streamsx/inet/http/HTTPUtils.java index 826933d..430a474 100644 --- a/com.ibm.streamsx.inet/impl/java/src/com/ibm/streamsx/inet/http/HTTPUtils.java +++ b/com.ibm.streamsx.inet/impl/java/src/com/ibm/streamsx/inet/http/HTTPUtils.java @@ -12,9 +12,11 @@ import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; +import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.logging.Logger; import java.security.SecureRandom; import java.security.cert.X509Certificate; @@ -31,8 +33,13 @@ import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.impl.conn.BasicClientConnectionManager; +import com.ibm.streams.operator.logging.TraceLevel; + public class HTTPUtils { + static final String CLASS_NAME="com.ibm.streamsx.inet.http.HTTPUtils"; + private static Logger trace = Logger.getLogger(CLASS_NAME); + public static HttpURLConnection getNewConnection(String url) throws IOException { return (HttpURLConnection)new URL(url).openConnection(); @@ -59,9 +66,14 @@ public static String readFromStream(InputStream stream) { } public static Map getHeaderMap(List headers) { + if(headers == null) return Collections.emptyMap(); Map headerMap = new HashMap(headers.size()); for(String header : headers) { String[] headerParts = header.split(":\\s*", 2); + if(headerParts.length < 2) { + trace.log(TraceLevel.ERROR, "No ':' found in extraHeaders element '" + header + "', skipping"); + continue; + } String headerName = headerParts[0]; String headerValue = headerParts[1]; headerMap.put(headerName, headerValue);