Martin,

I override the validate method in my ActionForm, but the overriding method did nothing but return the result of a call to super.validate(). This didn't seem to make any difference.

Then I made a functional change (for an unrelated problem). There were a couple work fields stored in the form bean (ActionForm), called userAction and systemAction, that were being used to determine which buttons to display based on what the user was trying to do. I removed the field called systemAction..... And when I ran the next test, the system did a doPost but did not follow that with a doGet. I can't begin to imagine how this could have solved the problem.... I'm quite confused, but this one page seems to be working correctly now.

There is one more page that does a doPost and then a doGet before the next page is displayed. However, the action class for that page is forwarding control to another action class rather than to a JSP. So I suspect that doPost / doGet is correct. (Or else there is a different problem there.)

At any rate, thanks very much for your help.

Dom



Martin Gainty wrote:
Personally yes I would advise override the validate method Here is the
relevant doc
http://struts.apache.org/api/org/apache/struts/action/ActionForm.html
(most notably implementing Serializable) with the end result
to display the ActionError message /*and ultimately */..
process the message returned by ActionError
Keep in mind if your validate method returns null you will pass to
Action.execute
HTH,
Martin-
----- Original Message -----
From: "Dom Incollingo" <[EMAIL PROTECTED]>
To: "Struts Users Mailing List" <user@struts.apache.org>
Sent: Sunday, April 03, 2005 7:30 PM
Subject: Re: Form Submitted Twice



Martin,

My ActionForm subclasses the struts ValidatorForm class.  But it does
not override the validate method.  It just uses whatever validate method
it inherits.  I checked the source code for the version of ValidatorForm
I am using (the one that came with Struts 1.2.4), and it returns an
ActionErrors object.

Does the validate method need to be overridden in the ActionForm
subclass?  Thanks.

Dom

Martin Gainty wrote:

Dom-
This depends on the return of  your ActionForm validate method
If you can show us the code and I'll take a look at it tonite
Thanks,
Martin-
----- Original Message -----
From: "Dom Incollingo" <[EMAIL PROTECTED]>
To: "Struts Users Mailing List" <user@struts.apache.org>
Sent: Sunday, April 03, 2005 4:25 PM
Subject: Re: Form Submitted Twice




Martin,

Thanks very much for the info.

I've tried to follow this pattern, both in the servlet-mapping in the
web.xml:


<servlet-mapping> <servlet-name>pets</servlet-name> <url-pattern>/action/*</url-pattern> </servlet-mapping>

and in the action element in the struts-config:

 <action
   path="/petDetail"
   type="com.dom.struts.pets.action.PetDetailAction"
   scope="request"
   name="petDetailForm"
   validate="true"
   input="/petDetail.jsp">
   <forward name="OwnerList" path="/action/getOwnerList"/>
   <forward name="OwnerDetail" path="/action/ownerDetail"/>
   <forward name="PetList" path="/action/getPetList"/>
   <forward name="Success" path="/petDetail.jsp"/>
   <forward name="Failure" path="/petDetail.jsp"/>
   <forward name="Logoff" path="/action/logout"/>
 </action>

Evidently, something is not set up correctly, but it's not obvious to me
where the problem lies.  I'm trying to step thru debug (using Eclipse
with Tomcat) to see if I can figure out what struts is having a problem
with.

Thanks.

Dom


Martin Gainty wrote:


Dom
Apparently the action tag was not setup properly to ensure validation

before


posting to RequestProcessor
To quote James Goodwill and Rick Hightower
For the purposes of simplicity, our sample legacy Web resource will be

a

servlet. Essentially, you want the servlet's doGet method to be called

only


if the ActionForm validates
e.g.
<servlet-mapping>
      <servlet-name>legacy</servlet-name>
      <url-pattern>/legacy/roar</url-pattern>
  </servlet-mapping>

Thus, posts to /legacy/roar would cause this servlet's doPost method to

be


called. Now, to map this servlet as an action that acts as a form

handler,


you need to do this:

      <action
          path="/legacy"
          forward="/legacy/roar"
          input="/form/userForm.jsp"
          name="userForm"
          parameter="/legacy/roar"
          validate="true"
          scope="request"
          />
thus
validate attribute is set to true in the action mapping for this

servlet, so


the execute method of the ForwardAction is called ONLY if the

ActionForm

(UserForm) validates (returns no ActionError objects).

Makes sense?
Martin-

----- Original Message -----
From: "Dom Incollingo" <[EMAIL PROTECTED]>
To: "Struts User" <user@struts.apache.org>
Sent: Saturday, April 02, 2005 6:34 PM
Subject: Form Submitted Twice





Hello,

I'm using Struts 1.2.4 (along with the validator framework), and I've
noticed that for my forms that do a Post, the action class is executed
twice.  I put log statements in my Action class, in the validator
classes, in the Struts ActionServlet, and in the JSP to try to figure
out what is happening.  The sequence of events is as follows:

- User presses Update button on a JSP
- doPost method invoked (ActionServlet)
- Struts validation methods invoked
- execute method (Action class) entered
- execute method (Action class) returns forward action of Success
- processing returns to the same JSP

.........................................................................

- doGet method invoked (ActionServlet)
- Struts validation methods invoked
- execute method (Action class) entered
- processing returns to the same JSP
- web page is displayed on browser

Everything prior to the doGet looks normal. I can't understand why

the

JSP submits a Get request when it should display. The method

specified

in the JSP's form (there is only one form in the JSP) is a Post, not a
Get.  The JSP does not contain any form submission via JavaScript.

I also notice that if I change the method in the JSP's form from Post

to

Get, this problem goes away:  the form is submitted only once!

In a related problem, I have a JSP that does have a form with a method
of Get, but the user never clicks on a button to submit the form.
Instead, the user clicks on a link with a value like:



http://localhost:8080/pets/action/petDetail?userAction=Display&type=Pet&id=2

I expect processing to go to the Action class associated with
'petDetail'.  Processing does go there, but first a 'doGet' is

processed

in the ActionServlet, even though a form was not submitted.

Has anyone seen these problems or know what is happening here?

Thanks

very much for your assistance.

Dom

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




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


-- Linux is like a teepee: no Windows, no Gates, Apache inside.

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




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


-- Linux is like a teepee: no Windows, no Gates, Apache inside.

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




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


-- Linux is like a teepee: no Windows, no Gates, Apache inside.

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



Reply via email to