Author: woonsan
Date: Fri Dec 11 11:22:34 2009
New Revision: 889578

URL: http://svn.apache.org/viewvc?rev=889578&view=rev
Log:
JS2-1087: Changes to read query parameter only for portal path param.

Added:
    
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
   (with props)
    
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
   (with props)
Modified:
    
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/container/url/impl/PortalURLValveImpl.java

Modified: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/container/url/impl/PortalURLValveImpl.java
URL: 
http://svn.apache.org/viewvc/portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/container/url/impl/PortalURLValveImpl.java?rev=889578&r1=889577&r2=889578&view=diff
==============================================================================
--- 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/container/url/impl/PortalURLValveImpl.java
 (original)
+++ 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/container/url/impl/PortalURLValveImpl.java
 Fri Dec 11 11:22:34 2009
@@ -17,6 +17,8 @@
 
 package org.apache.jetspeed.container.url.impl;
 
+import java.util.Map;
+
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletRequestWrapper;
 
@@ -27,6 +29,7 @@
 import org.apache.jetspeed.pipeline.valve.AbstractValve;
 import org.apache.jetspeed.pipeline.valve.ValveContext;
 import org.apache.jetspeed.request.RequestContext;
+import org.apache.jetspeed.util.HttpUtils;
 
 /**
  * Creates the PortalURL for the current Request
@@ -91,7 +94,15 @@
         
         if (pathInfoParamAllowed)
         {
-            String param = 
servletRequest.getParameter(PortalURL.PATH_INFO_QUERY);
+            String param = null;
+            
+            Map<String, String []> queryParamMap = 
HttpUtils.parseQueryString(servletRequest.getQueryString());
+            String [] pathInfoParams = 
queryParamMap.get(PortalURL.PATH_INFO_QUERY);
+            
+            if (pathInfoParams != null && pathInfoParams.length != 0)
+            {
+                param = pathInfoParams[0];
+            }
             
             if (param == null)
             {

Added: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
URL: 
http://svn.apache.org/viewvc/portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java?rev=889578&view=auto
==============================================================================
--- 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
 (added)
+++ 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
 Fri Dec 11 11:22:34 2009
@@ -0,0 +1,93 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.jetspeed.util;
+
+import java.io.UnsupportedEncodingException;
+import java.net.URLDecoder;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.commons.lang.StringUtils;
+
+/**
+ * HttpUtils
+ * 
+ * @version $Id$
+ */
+public class HttpUtils
+{
+    private HttpUtils()
+    {
+    }
+    
+    public static Map<String, String[]> parseQueryString(String queryString)
+    {
+        return parseQueryString(queryString, "ISO-8859-1");
+    }
+    
+    public static Map<String, String[]> parseQueryString(String queryString, 
String encoding)
+    {
+        if (StringUtils.isBlank(queryString))
+        {
+            return Collections.emptyMap();
+        }
+        
+        Map<String, String[]> paramMap = new HashMap<String, String[]>();
+        
+        for (String pair : StringUtils.split(queryString, "&"))
+        {
+            String [] nameAndValue = StringUtils.split(pair, "=", 2);
+            
+            if (nameAndValue.length == 2)
+            {
+                String name = nameAndValue[0];
+                String value = nameAndValue[1];
+                
+                if (encoding != null)
+                {
+                    try
+                    {
+                        name = URLDecoder.decode(name, encoding);
+                        value = URLDecoder.decode(value, encoding);
+                    }
+                    catch (UnsupportedEncodingException e)
+                    {
+                        throw new IllegalArgumentException("Unsupported 
encoding: " + encoding);
+                    }
+                }
+                
+                String [] values = paramMap.get(name);
+                
+                if (values == null)
+                {
+                    paramMap.put(name, new String [] { value });
+                }
+                else
+                {
+                    String [] newValues = new String[values.length + 1];
+                    System.arraycopy(values, 0, newValues, 0, values.length);
+                    newValues[values.length] = value;
+                    paramMap.put(name, newValues);
+                }
+            }
+        }
+        
+        return paramMap;
+    }
+    
+}

Propchange: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
------------------------------------------------------------------------------
    svn:keywords = Id

Propchange: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/main/java/org/apache/jetspeed/util/HttpUtils.java
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Added: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
URL: 
http://svn.apache.org/viewvc/portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java?rev=889578&view=auto
==============================================================================
--- 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
 (added)
+++ 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
 Fri Dec 11 11:22:34 2009
@@ -0,0 +1,89 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.jetspeed.util;
+
+import java.util.Map;
+
+import junit.framework.TestCase;
+
+/**
+ * TestHttpUtils
+ * 
+ * @version $Id$
+ */
+public class TestHttpUtils extends TestCase
+{
+
+    public void testBasicParsing() throws Exception
+    {
+        String queryString = "a=1&b=2&c=3";
+        Map<String, String []> queryParamMap = 
HttpUtils.parseQueryString(queryString);
+        
+        assertNotNull(queryParamMap);
+        
+        assertNotNull(queryParamMap.get("a"));
+        assertEquals(1, queryParamMap.get("a").length);
+        assertEquals("1", queryParamMap.get("a")[0]);
+        
+        assertNotNull(queryParamMap.get("b"));
+        assertEquals(1, queryParamMap.get("b").length);
+        assertEquals("2", queryParamMap.get("b")[0]);
+        
+        assertNotNull(queryParamMap.get("c"));
+        assertEquals(1, queryParamMap.get("c").length);
+        assertEquals("3", queryParamMap.get("c")[0]);
+    }
+    
+    public void testMultiValueParsing() throws Exception
+    {
+        String queryString = "a=1&b=2&c=3&a=11&b=22&a=111";
+        Map<String, String []> queryParamMap = 
HttpUtils.parseQueryString(queryString);
+        
+        assertNotNull(queryParamMap);
+        
+        assertNotNull(queryParamMap.get("a"));
+        assertEquals(3, queryParamMap.get("a").length);
+        assertEquals("1", queryParamMap.get("a")[0]);
+        assertEquals("11", queryParamMap.get("a")[1]);
+        assertEquals("111", queryParamMap.get("a")[2]);
+        
+        assertNotNull(queryParamMap.get("b"));
+        assertEquals(2, queryParamMap.get("b").length);
+        assertEquals("2", queryParamMap.get("b")[0]);
+        assertEquals("22", queryParamMap.get("b")[1]);
+        
+        assertNotNull(queryParamMap.get("c"));
+        assertEquals(1, queryParamMap.get("c").length);
+        assertEquals("3", queryParamMap.get("c")[0]);
+    }
+    
+    public void testEncodedMultiValueParsing() throws Exception
+    {
+        String queryString = "param+1=value+1&param%202=value%202";
+        Map<String, String []> queryParamMap = 
HttpUtils.parseQueryString(queryString);
+        
+        assertNotNull(queryParamMap);
+        
+        assertNotNull(queryParamMap.get("param 1"));
+        assertEquals(1, queryParamMap.get("param 1").length);
+        assertEquals("value 1", queryParamMap.get("param 1")[0]);
+        
+        assertNotNull(queryParamMap.get("param 2"));
+        assertEquals(1, queryParamMap.get("param 2").length);
+        assertEquals("value 2", queryParamMap.get("param 2")[0]);
+    }
+}

Propchange: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
------------------------------------------------------------------------------
    svn:keywords = Id

Propchange: 
portals/jetspeed-2/portal/trunk/components/jetspeed-portal/src/test/java/org/apache/jetspeed/util/TestHttpUtils.java
------------------------------------------------------------------------------
    svn:mime-type = text/plain



---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to