Reputation: 11233
I have some jQuery that looks like this:
$.ajax({
type: "POST",
url: "/Customer/CancelSubscription/<%= Model.Customer.Id %>",
contentType: "application/json",
success: refreshTransactions,
error: function(xhr, ajaxOptions, thrownError) {
alert("Failed to cancel subscription! Message:" + xhr.statusText);
}
});
If the action being called causes an exception it will ultimately get picked up by the Global.asax Application_Error where I have some code like this:
var ex = Server.GetLastError();
if (Request.ContentType.Contains("application/json"))
{
Response.StatusCode = 500;
Response.StatusDescription = ex.Message;
Response.TrySkipIisCustomErrors = true;
}
else
{
// some other way of handling errors ...
}
When I execute the script that does the post the Request.ContentType is always an empty string and therefore does not hit the first if block. Is there some other value that I should be putting in the ajax "contentType"? Or is there another way for me to tell asp.net that the content type should be "application/json"?
Clarification
The goal I am trying to achieve is to pass the exception message back to the ajax error event. Currently, even though the IF block is being bypassed, the error event correctly throws an alert box but the message is "Not Found".
As you can see I am trying to set the exeception message to the Response.StatusDescription which I believe the xhr.statusText in the ajax error is set to.
Upvotes: 16
Views: 70200
Reputation: 4650
Use this to default content type.
$.ajaxSetup({ contentType: "application/json; charset=utf-8", });
Upvotes: 1
Reputation: 15275
To set custom headers in the XmlHTTPRequest, you need to utilize the beforeSend() option function in the jQuery AJAX Call. Use that function to set additional headers, as described in the jQuery API documenation.
Example:
$.ajax({
type: "POST",
url: "/Customer/CancelSubscription/<%= Model.Customer.Id %>",
beforeSend: function(xhr) {
xhr.setRequestHeader( "Content-type", "application/json" );
},
success: refreshTransactions,
error: function(xhr, ajaxOptions, thrownError) {
alert("Failed to cancel subscription! Message:" + xhr.statusText);
}
});
Upvotes: 6
Reputation: 56968
Accordiing to this article: http://encosia.com/2008/03/27/using-jquery-to-consume-aspnet-json-web-services/ "jQuery does not properly set the specified content-type when there is no data included. "
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "WebService.asmx/WebMethodName",
data: "{}",
dataType: "json"
});
Upvotes: 24
Reputation: 4485
If you are always returning json for Ajax errors, then you can just use the following to detect that it is an Ajax call:
// jQuery sets a header of 'x-requested-with' in all requests
string[] ajaxHeader = httpRequest.Headers.GetValues("x-requested-with");
if (ajaxHeader != null && ajaxHeader.Length > 0)
{
return ajaxHeader[0].Equals("XMLHttpRequest", StringComparison.InvariantCultureIgnoreCase);
}
return false;
Upvotes: 0