Sample code for 30+ languages & platforms
Classic ASP

Demonstrates how to Handle Large Integers in JSON

See more JSON Examples

Demonstrates how to handle large integers in JSON. (Integers larger than what can fit in a 32-bit signed integer.)

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

' Let's say your JSON has this:

' {
' 	"id": 20000000001234567
' }

set json = Server.CreateObject("Chilkat.JsonObject")

success = json.LoadFile("qa_data/json/large_int.json")
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( json.LastErrorText) & "</pre>"
    Response.End
End If

' The integer is too large for a 32-bit signed integer that is returned by IntOf.
' The result will be something that wrapped around and could be negative.
' In this case it would be: -543893881
id = json.IntOf("id")
Response.Write "<pre>" & Server.HTMLEncode( "id: " & id) & "</pre>"

' The solution is to read the integer value as a string, and then use the features in your programming language
' to convert from a string to a 64-bit integer.
' 
' Alternatively, you may wish to simply hold the value as a string.  If, for example, the integer simply references
' an order ID, an account ID, etc., then there's no need to convert to an integer value.  You're not going to be doing
' mathematical operations on it anyway.  This is usually the case for large integers -- they typically exist
' in JSON as an account ID.

' You can get any JSON value as a string:
accountId = json.StringOf("id")
Response.Write "<pre>" & Server.HTMLEncode( "accountId: " & accountId) & "</pre>"

' Sample output:

' id: -543893881
' accountId: 20000000001234567

%>
</body>
</html>