I'm having a problem due to the frame-based layout of one of our pages.
Because the framing page (w/ the frameset/frames definition) gets the
request first, the ActionErrors in the request don't make it down to the
sub-frame pages. Is it possible to "hijack" the action errors via a scriplet
in the framing page that forwards the ActionErrors (as ActionErrors) along
to one or more framed JSPs.

I found the following posting, but I'd prefer to forward the actual
ActionErrors instead of just an HTML string representation.

Anyone have experience with this? What is the identifying name for the
ActionErrors object in the request?

Thanks,
- Alex

*** http://www.mail-archive.com/struts-user@jakarta.apache.org/msg22734.html
***

Solved: ActionErrors within frames manually forwarded

----------------------------------------------------------------------------
----

From: holger.wiechert 
Subject: Solved: ActionErrors within frames manually forwarded 
Date: Tue, 05 Feb 2002 10:42:10 -0800 

----------------------------------------------------------------------------
----

Well, after an eternity, the problem found was
that the ApplicationResources property "errors.header" 
had a value with double quotes in it (like <font color="red">).
That spoiled the src string in the frame page.

Have fun,
Holger

-----Ursprüngliche Nachricht-----
Von:    [EMAIL PROTECTED] [SMTP:[EMAIL PROTECTED]]
Gesendet am:    Dienstag, 5. Februar 2002 12:37
An:     [EMAIL PROTECTED]
Betreff:        ActionErrors within frames manually forwarded

Hi,

I've spent some time checking the list for this issue,
but I could only find related topics, that didn't really help. 
In case that this has been answered before, please ignore it
and send me a link.

I think that there must be something I've missed
when using the Struts validation feature within frames.
In short: I'm trying to manually retrieve and "forward" the ActionErrors
within a frame definition page (which is the "input" page
for a mapping). But those manually set request parameters
are gone when I access them.

The situation is as follows:

The page myframe.jsp consists of two frames: 
mynavigation.jsp and myContent.jsp. 
myContent.jsp is the JSP that is validated. 
In case that a validation error (ActionError) occurs,
the follwoing (relevant) events occur (correct me if I'm wrong)
- Struts puts the ActionErrors I created within validate into the request
- a forward to the "input" page is done as defined in the struts-config (in
  my case the "action" entry is:
    <action  path="/myContentActionPath"
             type="some.SomeAction"
             name="contentForm"
             scope="session"
             validate="true"
             input="/myframe.jsp">
      <forward name="back" path="/somePrev.jsp"/>
      <forward name="next" path="/someNext.jsp"/>
    </action>

  so it leads to the frame page.
- within the myframe.jsp, two new requests are created: one for each frame

But I think I should still be able to access the request with the
ActionErrors
within the frame definition page. So in myframe.jsp I could do something
like:

myframe.jsp:
<%@ page language="java" %>
<%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
<html:html>
<head>
  <html:base/> 
  <title>MyTitle</title>
        <meta http-equiv="Content-Type" content="text/html;
charset=iso-8859-1">
</head>
<frameset cols="150,*" frameborder="no" border="0" framespacing=0> 
  <frame src="myNavigation.jsp" NAME="Menue">
  <frame src="myContent.jsp?manuallySetParam=<html:errors 
property="myErrorProperty"/>" NAME="content">
  </frameset>
<noframes>
</noframes> 
</html:html>


in order to retrieve the ActionError String for property "myErrorProperty"
within the content page:

myContent.jsp:

...

<P> <%= request.getParameter("manuallySetParam") %> </P>

....


This - I agree - doesn't look elegant, but at least it should work.

If I have the input page defined as a pure jsp (no frames),
the html:errors are retrieved as expected.

Are there any ideas, why the parameter "manuallySetParam" does not
contain the error message of key "myErrorProperty" ?

Help and/or design suggestions greatly appreciated!

Thanks in advance,
Holger

--
To unsubscribe, e-mail:   <mailto:[EMAIL PROTECTED]>
For additional commands, e-mail: <mailto:[EMAIL PROTECTED]>

Reply via email to