944,183 Members | Top Members by Rank

Ad:
Nov 27th, 2007
0

ajax server-returned message?

Expand Post »
hi,

i understand that the xmlHttp.responseText; attribute would return the server's message, but is there any way to get only ajax object's error messages?

see, i have a case.

lets say i have two different span on my page.

<span id="system"/>
<span id="display"/>

if ajax's object is throwing an error, i want it displayed on 'system' span. Otherwise if everything's normal, a tabled result will show in 'display' span. Is this possible?
Similar Threads
Reputation Points: 10
Solved Threads: 0
Light Poster
adrive is offline Offline
34 posts
since Oct 2007
Nov 27th, 2007
0

Re: ajax server-returned message?

If by 'error message' you mean an error in the server side code; the error message is returned in the response text. If the error message is generated by conventional means; the xmlhttp object's 'status' property will be anything but 200, where 'anything but' is one of the standard HTTP status codes: http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html The 400+ range off codes are usually errors.

If you mean an error in the client-side code; use some try/catch blocks or pre-checks to find the error and output the message.
Moderator
Featured Poster
Reputation Points: 522
Solved Threads: 64
Veteran Poster
MattEvans is offline Offline
1,091 posts
since Jul 2006
Nov 27th, 2007
0

Re: ajax server-returned message?

hmm, what i meant were the exception errors thrown from server side (in my case, php).

let's say after i do an insert, an exception was thrown from the server, i need to be able to identify whether an exception was thrown on the client side's ajax response.

i'm thinking of sending a true boolean on each successful transaction if ajax's object can't automatically group exceptions on a...say, responseError instead of mixing errors and non-errors.
Reputation Points: 10
Solved Threads: 0
Light Poster
adrive is offline Offline
34 posts
since Oct 2007
Nov 27th, 2007
0

Re: ajax server-returned message?

An uncaught exception server side should cause the response to be an 'error 500 internal server error'. I think PHP generates its own descriptive error pages; but it still may respond with a status other than 200.. If you didn't know; every response from a server starts with a 'header' which has important information; a status code, the page's content-type, user-provided data, and a few other things. We don't see that in view-source, and PHP doesn't force you to consider it, but it's there. Use this http://web-sniffer.net/ to view the header of a page that raises an error. See if the HTTP status code is something other than "HTTP/1.1 200 OK". The property ajaxobject.status returns the number of the status code: in this case 200. You can't split up the response from a server into 'errors' or 'non-errors' unless you define how to split it up. There is no such thing as an 'error' in a valid response : it is all basically plain text. The header tells you what the response should be treated as. [ and you can, via PHP, set the response to have any header/status you desire ]
Last edited by MattEvans; Nov 27th, 2007 at 5:34 am.
Moderator
Featured Poster
Reputation Points: 522
Solved Threads: 64
Veteran Poster
MattEvans is offline Offline
1,091 posts
since Jul 2006
Nov 27th, 2007
0

Re: ajax server-returned message?

hi, im not entirely fluent in the http headers, but i just did a test,

with an ajax page that calls php to save something. I then tried throwing an exception from php, but ajax's status is still 200.

So does this mean i have to return other http status code manually incase i catch an exception?
Reputation Points: 10
Solved Threads: 0
Light Poster
adrive is offline Offline
34 posts
since Oct 2007
Nov 28th, 2007
0

Re: ajax server-returned message?

Click to Expand / Collapse  Quote originally posted by adrive ...
hi, im not entirely fluent in the http headers, but i just did a test,

with an ajax page that calls php to save something. I then tried throwing an exception from php, but ajax's status is still 200.

So does this mean i have to return other http status code manually incase i catch an exception?
Do you mean exceptions like: a try, catch block and throw in PHP5?

XHR object reflects the HTTP Request and Response in the HTTP protocol. Since PHP5 exceptions are only on the PHP code level, they are not seen as an exception by XHR.
Only HTTP Response Codes are reflected in the XHR object.

What you can do is depending on the format of your HTTP Response, let the client know that an exception was encountered.
For this you need a more structured format than just plain text, maybe JSON or XML. XHR understands XML natively and thus will parse it out into a DOM Object that you can work with. JavaScript can parse JSON with a simple eval().

For example w/ XML:

JavaScript / DHTML / AJAX Syntax (Toggle Plain Text)
  1. <?php
  2. // example exception handling for XHR in XML
  3.  
  4. // set content-type as xml
  5. header('Content-Type: text/xml');
  6.  
  7.  
  8. // PHP 5
  9. try {
  10. doSomething();
  11. } catch (Exception $e) {
  12. // handle either error here
  13. echo '<reponse>';
  14. echo '<exception msg="'.$e->getMessage().'" />';
  15. echo '</response>';
  16. exit();
  17. }
  18. ?>

For example w/ JSON:

JavaScript / DHTML / AJAX Syntax (Toggle Plain Text)
  1. <?php
  2. // example exception handling for XHR in JSON format
  3.  
  4. // set content-type as javascript
  5. header('Content-Type: text/javascript');
  6.  
  7.  
  8. // PHP 5
  9. try {
  10. doSomething();
  11. } catch (Exception $e) {
  12. // handle either error here
  13. echo '{exception: {msg:\''.$e->getMessage().'\'}}';
  14. exit();
  15. }
  16. ?>

Then on your client side:

If you use XML, get the XHR.responseXML DOM object after the XHR response is received. Traverse the DOM tree for the exception node and get its message attribute value.
If you use JSON for example, just eval("(".XHR.responsetext.")"); saving it to a variable and get the exception property.

You could also have PHP modify the HTTP Response to reflect an exception occurring in the PHP code. Then you can test for exceptions in the XHR Object directly.

Note: The HTTP Response is just plain text. XHR will only parse out the HTTP headers and body into the XHR properties. It cannot understand an exception in any server side language. You have to code this into your Client.
Moderator
Reputation Points: 457
Solved Threads: 101
Nearly a Posting Virtuoso
digital-ether is offline Offline
1,250 posts
since Sep 2005
Nov 28th, 2007
0

Re: ajax server-returned message?

Quote ...
So does this mean i have to return other http status code manually incase i catch an exception?
That's what I would do; if PHP doesn't abort with true HTTP errors, then catch every possible error at the PHP level, set a 4xx or 5xx error status code and respond the error message, otherwise set a 200 status ( its the default so you dont have to do anything ) and respond a 'success' message or whatever else it is that you want to respond with on success.

I forgot to mention, if using headers manually; you must set the status and header before responding any other content - this might mean you have to buffer output until you're sure that the response is error free, or decide very quickly whether the response is an error or not. Also, you'd have to mark en entire response as either an error or a success, so, you wouldn't be able to mix error messages with success messages.
Moderator
Featured Poster
Reputation Points: 522
Solved Threads: 64
Veteran Poster
MattEvans is offline Offline
1,091 posts
since Jul 2006
Nov 28th, 2007
0

Re: ajax server-returned message?

thanks guys
Reputation Points: 10
Solved Threads: 0
Light Poster
adrive is offline Offline
34 posts
since Oct 2007

This thread is more than three months old

No one has posted to this discussion for at least three months. Please let old threads die and do not reply to them unless you feel you have something new and valuable to contribute that absolutely must be added to make the discussion complete. Otherwise, please start a new thread in this forum instead.
Message:
Previous Thread in JavaScript / DHTML / AJAX Forum Timeline: alert dialog box
Next Thread in JavaScript / DHTML / AJAX Forum Timeline: how to delete old session value





About Us | Contact Us | Advertise | Acceptable Use Policy
Forum Index | Build Custom RSS Feed


Follow us on Twitter


© 2011 DaniWeb® LLC