[ 
https://issues.apache.org/jira/browse/PLUTO-745?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Neil Griffin closed PLUTO-745.
------------------------------
       Resolution: Fixed
         Assignee: Neil Griffin  (was: Scott Nicklous)
    Fix Version/s: 3.0.2

[~petermeyer]: Thanks for reporting this issue!

Fixed in commit 
[0ef804ed309f0b212a3b486cae2c4e06ee0583a7|https://github.com/apache/portals-pluto/commit/0ef804ed309f0b212a3b486cae2c4e06ee0583a7].

> Context root with "/" in the middle leads to an error
> -----------------------------------------------------
>
>                 Key: PLUTO-745
>                 URL: https://issues.apache.org/jira/browse/PLUTO-745
>             Project: Pluto
>          Issue Type: Bug
>          Components: portal driver
>    Affects Versions: 3.0.1
>            Reporter: Peter Meyer
>            Assignee: Neil Griffin
>            Priority: Major
>             Fix For: 3.0.2
>
>
> A portlet application with context root /online/ReferenzPortlets leads to an 
> error when submitting a form - the url of the form cannot be executed - HTTP 
> 400.
> This is due to the character which replaces the middle "/" in the portlet id 
> part of the URL.
> To my analyses the problem arises in the class 
> org.apache.pluto.driver.url.impl.PortalURLParserImpl in the method "toString" 
> at line 454.
> for (String pid : portalURL.getPortletIds()) {
>  pids.add(pid);
>  buffer.append(TOKEN_DELIM).append(PREFIX).append(PORTLET_ID);
>  try {
>  buffer.append(URLEncoder.encode(pid, "UTF-8"));
>  } catch(Exception e) {
>  LOG.warn("Could not encode pid=" + pid);
>  }
>  buffer.append(DELIM).append(String.valueOf(pids.indexOf(pid)));
>  }
> I suggest to replace the expression URLEncoder.encode(pid, "UTF-8") with 
> urlEncode(pid). In the decode part there is already the use of the urlDecode 
> method on the pid part of the URL.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to