views:

156

answers:

2

Hi guys,

I have a problem with IE7 regarding an ajax call that is made by jQuery.load function.

Basically the request works in cases where the URL string is not too long, but as soon as the URL gets very large it fails. Doing some debugging on the Ajax call I found this error:

URL: <blanked out security reasons but it's very long>
Content Type: 
Headers size (bytes): 0
Data size (bytes): 0
Total size (bytes): 0
Transferred data size (bytes): 0
Cached data: No
Error result: 0x800c0005
Error constant: INET_E_RESOURCE_NOT_FOUND
Error description: The server or proxy was not found
Extended error result: 0x7a
Extended error description: The data area passed to a system call is too small.

As you can see, it looks like nothing is being sent. Now this only happens on IE7 but not other browsers, with IE8 there is a small delay but still works. The same request works fine when the URL string is relatively small.

Now I need this working on IE7 for compatibility reasons and I cannot find workarounds for this so any help is greatly appreciated.

The actual ajax call is like this:

$("ID").load("url?lotsofparams",callbac func(){}); 

"lotsofparams" can vary, sometimes being small or very large. It's when the string is very large that I get the above error for IE7 only.

+3  A: 

Don't put the query string parameters into the the url.

The second parameter of .load() is made just for that. Should be:

$("ID").load("url", {
    foo:     "bar",
    morefoo: "morebar"
},callbac func(){}); 

or you can use $.post()

$.post("url", {
    foo:     "bar",
    morefoo: "morebar"
}, function(data){
   alert(data);
});

Since the .load() will internally use a "POST" request when parsing an object, you might consider to replace it with $.get() if you require a "GET" request.

jAndy
Hmm that's what I thought... and it's going to be a bit of a trouble as the that query string is built up in several places and stored in a variable in the form "var=val" strange it works with FF and IE8.
iQ
This is not a client-only change though, you should mention he's likely going to have to change things server-side for this to work, since neither solution is a `GET` anymore...that's an important caveat to add.
Nick Craver
@Nick: `.load()` is using `.get()` underneath.
jAndy
@jAndy: Not when you pass the data as an object, then it's a `POST`, [read the docs](http://api.jquery.com/load/) :) As a test, pull up firebug, you can see this POSTing: http://jsfiddle.net/FyEGh/
Nick Craver
@Nick: omg omg omg ! schooled
jAndy
+2  A: 

since load uses HTTP Get method, there is limit to the size of the url, which is 4KB as far as I know. So instead of GET, use $.ajax with HTTP Post option. Post has no limit.

use the following code.

$.ajax({
                url: url,
                type: "POST",
                async: true,
                data: {name1: value1, name2: value2, ...}, // put your data.
                success: function(data, textStatus) {
                 $("ID").html(data);

               }
       });
mohang
The approach is right, the limit of a GET request however is per-browser, and depends on version, so it's all over the place.
Nick Craver
yep this approach i can easily integrate with the existing code, works well.
iQ