[
https://jira.jboss.org/jira/browse/JBSEAM-4209?page=com.atlassian.jira.pl...
]
Pete Muir updated JBSEAM-4209:
------------------------------
Assignee: (was: Norman Richards)
StringIndexOutOfBoundsException in RedirectHandler
--------------------------------------------------
Key: JBSEAM-4209
URL:
https://jira.jboss.org/jira/browse/JBSEAM-4209
Project: Seam
Issue Type: Bug
Affects Versions: 2.1.2.CR2
Reporter: Nicko Cadell
StringIndexOutOfBoundsException in RedirectHandler
This exception is thrown if ViewExpiredException is thown and I'm hndling this with a
redirect back to the same page: i.e. my exception config looks like:
{code}
<exception class="javax.faces.application.ViewExpiredException">
<redirect />
</exception>
{code}
AND I am using the <web:rewrite-filter /> to rewrite the URLs.
The code in RedirectHandler assumes that the request servlet path will contain a URL that
matches up to one of the view by changing the file extension. This is not always the case.
In this case the RewriteFilter is intercepting the path, which does not contain a .seam
extension.
The following exception is thrown:
{code}
java.lang.StringIndexOutOfBoundsException: String index out of range: -1
at java.lang.String.substring(String.java:1938)
at org.jboss.seam.exception.RedirectHandler.handle(RedirectHandler.java:39)
at org.jboss.seam.exception.Exceptions.handle(Exceptions.java:76)
at
org.jboss.seam.web.ExceptionFilter.endWebRequestAfterException(ExceptionFilter.java:114)
at org.jboss.seam.web.ExceptionFilter.doFilter(ExceptionFilter.java:70)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.RedirectFilter.doFilter(RedirectFilter.java:45)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:178)
at org.ajax4jsf.webapp.BaseFilter.handleRequest(BaseFilter.java:290)
at org.ajax4jsf.webapp.BaseFilter.processUploadsAndHandleRequest(BaseFilter.java:368)
at org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:495)
at org.jboss.seam.web.Ajax4jsfFilter.doFilter(Ajax4jsfFilter.java:56)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.web.LoggingFilter.doFilter(LoggingFilter.java:60)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:69)
at org.jboss.seam.servlet.SeamFilter$FilterChainImpl.doFilter(SeamFilter.java:73)
at org.jboss.seam.servlet.SeamFilter.doFilter(SeamFilter.java:158)
{code}
It looks like the RewriteFilter process() method does have some commented out code to
wrap the request so that the call to getServletPath() would return the rewritten URL (i.e.
something that could be converted to a view id by the RedirectHandler). I assume that the
wrapped request was commented out to resolve some other issue.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
https://jira.jboss.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira