| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 | <%'Februari 2014 - Version 1.17 by Gerrit van KuipersClass AspJSON	Public data	Private p_JSONstring	private aj_in_string, aj_in_escape, aj_i_tmp, aj_char_tmp, aj_s_tmp, aj_line_tmp, aj_line, aj_lines, aj_currentlevel, aj_currentkey, aj_currentvalue, aj_newlabel, aj_XmlHttp, aj_RegExp, aj_colonfound	Private Sub Class_Initialize()		Set data = Collection()	    Set aj_RegExp = new regexp	    aj_RegExp.Pattern = "\s{0,}(\S{1}[\s,\S]*\S{1})\s{0,}"	    aj_RegExp.Global = False	    aj_RegExp.IgnoreCase = True	    aj_RegExp.Multiline = True	End Sub	Private Sub Class_Terminate()		Set data = Nothing	    Set aj_RegExp = Nothing	End Sub	Public Sub loadJSON(inputsource)		inputsource = aj_MultilineTrim(inputsource)		If Len(inputsource) = 0 Then Err.Raise 1, "loadJSON Error", "No data to load."				select case Left(inputsource, 1)			case "{", "["			case else				Set aj_XmlHttp = Server.CreateObject("Msxml2.ServerXMLHTTP")				aj_XmlHttp.open "GET", inputsource, False				aj_XmlHttp.setRequestHeader "Content-Type", "text/json"				aj_XmlHttp.setRequestHeader "CharSet", "UTF-8"				aj_XmlHttp.Send				inputsource = aj_XmlHttp.responseText				set aj_XmlHttp = Nothing		end select		p_JSONstring = CleanUpJSONstring(inputsource)		aj_lines = Split(p_JSONstring, Chr(13) & Chr(10))		Dim level(99)		aj_currentlevel = 1		Set level(aj_currentlevel) = data		For Each aj_line In aj_lines			aj_currentkey = ""			aj_currentvalue = ""			If Instr(aj_line, ":") > 0 Then				aj_in_string = False				aj_in_escape = False				aj_colonfound = False				For aj_i_tmp = 1 To Len(aj_line)					If aj_in_escape Then						aj_in_escape = False					Else						Select Case Mid(aj_line, aj_i_tmp, 1)							Case """"								aj_in_string = Not aj_in_string							Case ":"								If Not aj_in_escape And Not aj_in_string Then									aj_currentkey = Left(aj_line, aj_i_tmp - 1)									aj_currentvalue = Mid(aj_line, aj_i_tmp + 1)									aj_colonfound = True									Exit For								End If							Case "\"								aj_in_escape = True						End Select					End If				Next				if aj_colonfound then					aj_currentkey = aj_Strip(aj_JSONDecode(aj_currentkey), """")					If Not level(aj_currentlevel).exists(aj_currentkey) Then level(aj_currentlevel).Add aj_currentkey, ""				end if			End If			If right(aj_line,1) = "{" Or right(aj_line,1) = "[" Then				If Len(aj_currentkey) = 0 Then aj_currentkey = level(aj_currentlevel).Count				Set level(aj_currentlevel).Item(aj_currentkey) = Collection()				Set level(aj_currentlevel + 1) = level(aj_currentlevel).Item(aj_currentkey)				aj_currentlevel = aj_currentlevel + 1				aj_currentkey = ""			ElseIf right(aj_line,1) = "}" Or right(aj_line,1) = "]" or right(aj_line,2) = "}," Or right(aj_line,2) = "]," Then				aj_currentlevel = aj_currentlevel - 1			ElseIf Len(Trim(aj_line)) > 0 Then				if Len(aj_currentvalue) = 0 Then aj_currentvalue = aj_line				aj_currentvalue = getJSONValue(aj_currentvalue)				If Len(aj_currentkey) = 0 Then aj_currentkey = level(aj_currentlevel).Count				level(aj_currentlevel).Item(aj_currentkey) = aj_currentvalue			End If		Next	End Sub	Public Function Collection()		set Collection = Server.CreateObject("Scripting.Dictionary")	End Function	Public Function AddToCollection(dictobj)		if TypeName(dictobj) <> "Dictionary" then Err.Raise 1, "AddToCollection Error", "Not a collection."		aj_newlabel = dictobj.Count		dictobj.Add aj_newlabel, Collection()		set AddToCollection = dictobj.item(aj_newlabel)	end function	Private Function CleanUpJSONstring(aj_originalstring)		aj_originalstring = Replace(aj_originalstring, Chr(13) & Chr(10), "")		aj_originalstring = Mid(aj_originalstring, 2, Len(aj_originalstring) - 2)		aj_in_string = False : aj_in_escape = False : aj_s_tmp = ""		For aj_i_tmp = 1 To Len(aj_originalstring)			aj_char_tmp = Mid(aj_originalstring, aj_i_tmp, 1)			If aj_in_escape Then				aj_in_escape = False				aj_s_tmp = aj_s_tmp & aj_char_tmp			Else				Select Case aj_char_tmp					Case "\" : aj_s_tmp = aj_s_tmp & aj_char_tmp : aj_in_escape = True					Case """" : aj_s_tmp = aj_s_tmp & aj_char_tmp : aj_in_string = Not aj_in_string					Case "{", "["						aj_s_tmp = aj_s_tmp & aj_char_tmp & aj_InlineIf(aj_in_string, "", Chr(13) & Chr(10))					Case "}", "]"						aj_s_tmp = aj_s_tmp & aj_InlineIf(aj_in_string, "", Chr(13) & Chr(10)) & aj_char_tmp					Case "," : aj_s_tmp = aj_s_tmp & aj_char_tmp & aj_InlineIf(aj_in_string, "", Chr(13) & Chr(10))					Case Else : aj_s_tmp = aj_s_tmp & aj_char_tmp				End Select			End If		Next		CleanUpJSONstring = ""		aj_s_tmp = split(aj_s_tmp, Chr(13) & Chr(10))		For Each aj_line_tmp In aj_s_tmp			aj_line_tmp = replace(replace(aj_line_tmp, chr(10), ""), chr(13), "")			CleanUpJSONstring = CleanUpJSONstring & aj_Trim(aj_line_tmp) & Chr(13) & Chr(10)		Next	End Function	Private Function getJSONValue(ByVal val)		val = Trim(val)		If Left(val,1) = ":"  Then val = Mid(val, 2)		If Right(val,1) = "," Then val = Left(val, Len(val) - 1)		val = Trim(val)		Select Case val			Case "true"  : getJSONValue = True			Case "false" : getJSONValue = False			Case "null" : getJSONValue = Null			Case Else				If (Instr(val, """") = 0) Then					If IsNumeric(val) Then						getJSONValue = CDbl(val)					Else						getJSONValue = val					End If				Else					If Left(val,1) = """" Then val = Mid(val, 2)					If Right(val,1) = """" Then val = Left(val, Len(val) - 1)					getJSONValue = aj_JSONDecode(Trim(val))				End If		End Select	End Function	Private JSONoutput_level	Public Function JSONoutput()		dim wrap_dicttype, aj_label		JSONoutput_level = 1		wrap_dicttype = "[]"		For Each aj_label In data			 If Not aj_IsInt(aj_label) Then wrap_dicttype = "{}"		Next		JSONoutput = Left(wrap_dicttype, 1) & Chr(13) & Chr(10) & GetDict(data) & Right(wrap_dicttype, 1)	End Function    Public Function PrintJson        Response.AddHeader "Content-Type", "text/plain"        If IsEmpty(Request.QueryString("callback")) Then            Response.Write JSONoutput()        Else            Response.Write Request.QueryString("callback") & "(" & JSONoutput() & ")"        End If    End Function	Private Function GetDict(objDict)		dim aj_item, aj_keyvals, aj_label, aj_dicttype		For Each aj_item In objDict			Select Case TypeName(objDict.Item(aj_item))				Case "Dictionary"					GetDict = GetDict & Space(JSONoutput_level * 4)										aj_dicttype = "[]"					For Each aj_label In objDict.Item(aj_item).Keys						 If Not aj_IsInt(aj_label) Then aj_dicttype = "{}"					Next					If aj_IsInt(aj_item) Then						GetDict = GetDict & (Left(aj_dicttype,1) & Chr(13) & Chr(10))					Else						GetDict = GetDict & ("""" & aj_JSONEncode(aj_item) & """" & ": " & Left(aj_dicttype,1) & Chr(13) & Chr(10))					End If					JSONoutput_level = JSONoutput_level + 1										aj_keyvals = objDict.Keys					GetDict = GetDict & (GetSubDict(objDict.Item(aj_item)) & Space(JSONoutput_level * 4) & Right(aj_dicttype,1) & aj_InlineIf(aj_item = aj_keyvals(objDict.Count - 1),"" , ",") & Chr(13) & Chr(10))				Case Else					aj_keyvals =  objDict.Keys					GetDict = GetDict & (Space(JSONoutput_level * 4) & aj_InlineIf(aj_IsInt(aj_item), "", """" & aj_JSONEncode(aj_item) & """: ") & WriteValue(objDict.Item(aj_item)) & aj_InlineIf(aj_item = aj_keyvals(objDict.Count - 1),"" , ",") & Chr(13) & Chr(10))			End Select		Next	End Function	Private Function aj_IsInt(val)		aj_IsInt = (TypeName(val) = "Integer" Or TypeName(val) = "Long")	End Function	Private Function GetSubDict(objSubDict)		GetSubDict = GetDict(objSubDict)		JSONoutput_level= JSONoutput_level -1	End Function	Private Function WriteValue(ByVal val)		Select Case TypeName(val)			Case "Double", "Integer", "Long": WriteValue = val			Case "Null"						: WriteValue = "null"			Case "Boolean"					: WriteValue = aj_InlineIf(val, "true", "false")			Case Else						: WriteValue = """" & aj_JSONEncode(val) & """"		End Select	End Function	Private Function aj_JSONEncode(ByVal val)		val = Replace(val, "\", "\\")		val = Replace(val, """", "\""")		'val = Replace(val, "/", "\/")		val = Replace(val, Chr(8), "\b")		val = Replace(val, Chr(12), "\f")		val = Replace(val, Chr(10), "\n")		val = Replace(val, Chr(13), "\r")		val = Replace(val, Chr(9), "\t")		aj_JSONEncode = Trim(val)	End Function	Private Function aj_JSONDecode(ByVal val)		val = Replace(val, "\""", """")		val = Replace(val, "\\", "\")		val = Replace(val, "\/", "/")		val = Replace(val, "\b", Chr(8))		val = Replace(val, "\f", Chr(12))		val = Replace(val, "\n", Chr(10))		val = Replace(val, "\r", Chr(13))		val = Replace(val, "\t", Chr(9))		aj_JSONDecode = Trim(val)	End Function	Private Function aj_InlineIf(condition, returntrue, returnfalse)		If condition Then aj_InlineIf = returntrue Else aj_InlineIf = returnfalse	End Function	Private Function aj_Strip(ByVal val, stripper)		If Left(val, 1) = stripper Then val = Mid(val, 2)		If Right(val, 1) = stripper Then val = Left(val, Len(val) - 1)		aj_Strip = val	End Function	Private Function aj_MultilineTrim(TextData)		aj_MultilineTrim = aj_RegExp.Replace(TextData, "$1")	End Function	private function aj_Trim(val)		aj_Trim = Trim(val)		Do While Left(aj_Trim, 1) = Chr(9) : aj_Trim = Mid(aj_Trim, 2) : Loop		Do While Right(aj_Trim, 1) = Chr(9) : aj_Trim = Left(aj_Trim, Len(aj_Trim) - 1) : Loop		aj_Trim = Trim(aj_Trim)	end functionEnd Class%>
 |