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

Neil Griffin closed PLUTO-727.
------------------------------
    Resolution: Fixed

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

> PortletSession invalidated in the HEADER_PHASE gets recycled and reused in 
> the RENDER_PHASE
> -------------------------------------------------------------------------------------------
>
>                 Key: PLUTO-727
>                 URL: https://issues.apache.org/jira/browse/PLUTO-727
>             Project: Pluto
>          Issue Type: Bug
>          Components: portlet container
>    Affects Versions: 3.0.0, 3.0.1
>            Reporter: Neil Griffin
>            Assignee: Neil Griffin
>            Priority: Major
>             Fix For: 3.0.2
>
>
> As shown in the following example, session attributes set in the 
> {{HEADER_PHASE}} should not be available in the subsequent {{RENDER_PHASE}} 
> if the {{PortletSession}} is invalidated in the {{HEADER_PHASE}}:
> {code:java|title=MyPortlet.java}
> public class MyPortlet extends GenericPortlet {
>     @Override
>     public void renderHeaders(HeaderRequest headerRequest, HeaderResponse 
> headerResponse) {
>         PortletSesson portletSession = headerRequest.getPortletSession();
>         portletSession.setAttribute("foo", "1234");
>         portletSession.invalidate();
>     }
>     @Override
>     public void doView(RenderRequest renderRequest, RenderResponse 
> renderResponse) {
>         PortletSesson portletSession = renderRequest.getPortletSession();
>         String foo = (String) portletSession.getAttribute("foo");
>         if (foo == null) {
>             // Correct
>         }
>         else {
>             // Incorrect
>         }
>     }
> }
> {code}
> However, due to a cross-context issue incompatibility between Apache Pluto 
> and Apache Tomcat, the PortletSession invalidated in the {{HEADER_PHASE}} 
> gets recycled and reused in the {{RENDER_PHASE}}.
> The problem stems from a [special cross-context case found in Tomcat's 
> ApplicationHttpRequest.java 
> class|https://github.com/apache/tomcat/blob/TOMCAT_8_0_0/java/org/apache/catalina/core/ApplicationHttpRequest.java#L541-L542]
>  that recycles {{HttpSession}} objects even if they were previously 
> invalidated.
> The workaround is to keep track of invalidated {{HttpSession}} identifiers in 
> Apache Pluto and to clear the session attributes if Tomcat produces an 
> invalidated/recycled {{HttpSession}}.
> A similar problem of was reported in PLUTO-436 which required caused the 
> developer to add [comments in 
> PortletRequestContextImpl.java|https://github.com/apache/portals-pluto/blob/pluto-3.0.1/pluto-portal-driver-impl/src/main/java/org/apache/pluto/driver/services/container/PortletRequestContextImpl.java#L370-L377]
>  that describe the workaround.



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

Reply via email to