JavaScriptSerializer.MaxJsonLength exceeded. What’s the best practice for handling this?

I’ve got a large amound of data I’m sending down to the client using jQuery’s $.ajax() function. I’m calling a method in a ASP.NET web service that returns the JSON data. Everything is great for most searches, but when I’ve got a large data set to return I run into a issue with the JavaScriptSerializer MaxJsonLength property. What’s the best practice for handling this? I don’t want to just arbitrarily set a max length. Can I set the MaxJsonLength in the web service if the data being returned is larger than the current max or should I re-write and send down chucks of data to the client?

Here’s the relevant snippet from the web service:

Dictionary<string, object> jsonValuePairs = new Dictionary<string, object>();
//add some data to the dictionary...
return System.Web.Script.Serialization.JavaScriptSerializer.Serialize(jsonValuePairs);

Answers:

Thank you for visiting the Q&A section on Magenaut. Please note that all the answers may not help you solve the issue immediately. So please treat them as advisements. If you found the post helpful (or not), leave a comment & I’ll get back to you as soon as possible.

Method 1

The only way to set the maximum length for web methods that are called from client script is through the web.config file (below).
What is your issue with setting this?
I would do this every time over multiple xhr calls to stream parts of the data.

<system.web.extensions>
  <scripting>
      <webServices>
        <jsonSerialization maxJsonLength="500000">
        </jsonSerialization>
      </webServices>
  </scripting>
</system.web.extensions>

UPDATE: The default size is 2097152 which is equivalent to 4 MB of Unicode string data. Are you really going to send that much data back to the client? If so ouch and you prob need to look at the app design as the user experience will be slow and cumbersome.

Method 2

2147483647 is the correct value to use. Just to avoid confusion in the code you can use something like

var JsonSerializer = new JavaScriptSerializer();
JsonSerializer.MaxJsonLength = Int32.MaxValue;

Method 3

The maximum value for this property is 2147483647 according to this forum post.

I’ve not spent any time optimizing the data I return, yet (I’ll do that before anyone sees it) – but with this value set, IE has started giving me the ‘a script on the page is taking too long do you want to kill it’ message.

A solution would be to chunk the data – does anyone know of a nice way to do this (in jQuery ideally)? I could just do another ajax call in the success handler, of course.

Method 4

The maximum allowed length is the maximum value an Integer can hold which happens to be – 2147483647

Method 5

add this snippet to web.config :

<system.web.extensions>
<scripting>
  <webServices>
    <jsonSerialization maxJsonLength="2147483647"/>
  </webServices>
</scripting>

and in your c# code:

 JavaScriptSerializer jss = new JavaScriptSerializer();
 jss.MaxJsonLength = Int32.MaxValue;
 ...
 ...


All methods was sourced from stackoverflow.com or stackexchange.com, is licensed under cc by-sa 2.5, cc by-sa 3.0 and cc by-sa 4.0

0 0 votes
Article Rating
Subscribe
Notify of
guest

0 Comments
Inline Feedbacks
View all comments
0
Would love your thoughts, please comment.x
()
x