狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

asp讀取解析JSON的幾種方法

admin
2024年12月12日 17:57 本文熱度 417

方法一(使用MSScriptControl.ScriptControl):

<%

Dim sc4Json,arr0,json

InitScriptControl


json="{""name"":""123"",""content"":[{""id"":""1""},{""id"":""2""}]}"


Set jsonobj=getJSONObject(json)

'方法一

getJSArrayItem arr0,jsonobj.content,0

response.write jsonobj.name&"<br/>"&arr0.id&"<br/>"

'方法二

response.write sc4Json.Eval("jsonObject.name")&"<br/>"

response.write sc4Json.Eval("jsonObject.content[1].id")


Sub InitScriptControl

  Set sc4Json = Server.CreateObject("MSScriptControl.ScriptControl")

  sc4Json.Language = "JavaScript"

  sc4Json.AddCode "var itemTemp=null;function getJSArray(arr, index){itemTemp=arr[index];}"

End Sub


Function getJSONObject( strJSON )

  sc4Json.AddCode "var jsonObject = " & strJSON

  Set getJSONObject = sc4Json.CodeObject.jsonObject

End Function


Sub getJSArrayItem( objDest, objJSArray, index )

  On Error Resume Next

  sc4Json.Run "getJSArray",objJSArray, index

  Set objDest = sc4Json.CodeObject.itemTemp

  If Err.number=0 Then  Exit Sub End If

  objDest = sc4Json.CodeObject.itemTemp

End Sub

%>


方法二:

<%

Dim sc4Json

Sub InitScriptControl

Set sc4Json = Server.CreateObject("MSScriptControl.ScriptControl")

  sc4Json.Language = "JavaScript"

  sc4Json.AddCode "var itemTemp=null;function getJSArray(arr, index){itemTemp=arr[index];}"

End Sub


Function getJSONObject(strJSON)

  sc4Json.AddCode "var jsonObject = " & strJSON

  Set getJSONObject = sc4Json.CodeObject.jsonObject

End Function


Sub getJSArrayItem(objDest,objJSArray,index)

  On Error Resume Next

  sc4Json.Run "getJSArray",objJSArray, index

  Set objDest = sc4Json.CodeObject.itemTemp

  If Err.number=0 Then Exit Sub

  objDest = sc4Json.CodeObject.itemTemp

End Sub


Dim strTest

strTest = "{name:""alonely"", age:24, email:[""ycplxl1314@163.com"",""ycplxl1314@gmail.com""], family:{parents:[""父親"",""母親""],toString:function(){return ""家庭成員"";}}}"

Dim objTest

Call InitScriptControl

Set objTest = getJSONObject(strTest)

%>

<%=objTest.name%>的郵件地址是<%=sc4Json.eval_r("jsonObject.email[0]")%><BR>共有郵件地址<%=objTest.email.length%>個<BR>

<%

Dim father

getJSArrayItem father, objTest.family.parents, 0

Response.Write father

%>


方法三(類庫):

<%

'

'    VBS JSON 2.0.3

'    Copyright (c) 2009

'    Under the MIT (MIT-LICENSE.txt) license.

'


Const JSON_OBJECT    = 0

Const JSON_ARRAY    = 1


Class jsCore

Public Collection

Public Count

Public QuotedVars

Public Kind ' 0 = object, 1 = array


Private Sub Class_Initialize

  Set Collection = CreateObject("Scripting.Dictionary")

  QuotedVars = True

  Count = 0

End Sub


Private Sub Class_Terminate

  Set Collection = Nothing

End Sub


' counter

Private Property Get Counter

  Counter = Count

  Count = Count + 1

End Property


' – data maluplation

' — pair

Public Property Let Pair(p, v)

  If IsNull(p) Then p = Counter

  Collection(p) = v

End Property


Public Property Set Pair(p, v)

  If IsNull(p) Then p = Counter

  If TypeName(v) <> "jsCore" Then

    Err.Raise &hD, "class: class", "Incompatible types: '" & TypeName(v) & "'"

  End If

  Set Collection(p) = v

End Property


Public Default Property Get Pair(p)

  If IsNull(p) Then p = Count – 1

  If IsObject(Collection(p)) Then

    Set Pair = Collection(p)

  Else

    Pair = Collection(p)

  End If

End Property


' — pair

Public Sub Clean

  Collection.RemoveAll

End Sub


Public Sub Remove(vProp)

  Collection.Remove vProp

End Sub

' data maluplation


' encoding

Function jsEncode(str)

  Dim charmap(127), haystack()

  charmap(8)  = "\b"

  charmap(9)  = "\t"

  charmap(10) = "\n"

  charmap(12) = "\f"

  charmap(13) = "\r"

  charmap(34) = "\"""

  charmap(47) = "\/"

  charmap(92) = "\\"


  Dim strlen : strlen = Len(str) – 1

  ReDim haystack(strlen)


  Dim i, charcode

  For i = 0 To strlen

    haystack(i) = Mid(str, i + 1, 1)


    charcode = AscW(haystack(i)) And 65535

    If charcode < 127 Then

      If Not IsEmpty(charmap(charcode)) Then

        haystack(i) = charmap(charcode)

      ElseIf charcode < 32 Then

        haystack(i) = "\u" & Right("000″ & Hex(charcode), 4)

      End If

    Else

      haystack(i) = "\u" & Right("000″ & Hex(charcode), 4)

    End If

  Next


  jsEncode = Join(haystack, "")

End Function


' converting

Public Function toJSON(vPair)

  Select Case VarType(vPair)

  Case 0    ’ Empty

  toJSON = "null"

  Case 1    ’ Null

  toJSON = "null"

  Case 7    ’ Date

  ' toJSON = "new Date(" & (vPair – CDate(25569)) * 86400000 & ")"    ’ let in only utc time

  toJSON = """" & CStr(vPair) & """"

  Case 8    ’ String

  toJSON = """" & jsEncode(vPair) & """"

  Case 9    ’ Object

  Dim bFI,i

  bFI = True

  If vPair.Kind Then toJSON = toJSON & "[" Else toJSON = toJSON & "{"

  For Each i In vPair.Collection

    If bFI Then bFI = False Else toJSON = toJSON & ","


    If vPair.Kind Then

      toJSON = toJSON & toJSON(vPair(i))

    Else

      If QuotedVars Then

        toJSON = toJSON & """" & i & """:" & toJSON(vPair(i))

      Else

        toJSON = toJSON & i & ":" & toJSON(vPair(i))

      End If

    End If

  Next

  If vPair.Kind Then toJSON = toJSON & "]" Else toJSON = toJSON & "}"

  Case 11

    If vPair Then toJSON = "true" Else toJSON = "false"

  Case 12, 8192, 8204

    toJSON = RenderArray(vPair, 1, "")

  Case Else

    toJSON = Replace(vPair, ",", ".")

  End select

End Function


Function RenderArray(arr, depth, parent)

  Dim first : first = LBound(arr, depth)

  Dim last : last = UBound(arr, depth)


  Dim index, rendered

  Dim limiter : limiter = ","


  RenderArray = "["

  For index = first To last

    If index = last Then limiter = ""


    On Error Resume Next

    rendered = RenderArray(arr, depth + 1, parent & index & "," )


    If Err = 9 Then

      On Error GoTo 0

      RenderArray = RenderArray & toJSON(Eval("arr(" & parent & index & ")")) & limiter

    Else

      RenderArray = RenderArray & rendered & "" & limiter

    End If

  Next

  RenderArray = RenderArray & "]"

End Function


Public Property Get jsString

  jsString = toJSON(Me)

End Property


Sub Flush

  If TypeName(Response) <> "Empty" Then

    Response.Write(jsString)

  ElseIf WScript <> Empty Then

    WScript.Echo(jsString)

  End If

End Sub


Public Function Clone

  Set Clone = ColClone(Me)

End Function


Private Function ColClone(core)

  Dim jsc, i

  Set jsc = new jsCore

  jsc.Kind = core.Kind

  For Each i In core.Collection

    If IsObject(core(i)) Then

      Set jsc(i) = ColClone(core(i))

    Else

      jsc(i) = core(i)

    End If

  Next

  Set ColClone = jsc

End Function


End Class


Function jsObject

  Set jsObject = new jsCore

  jsObject.Kind = JSON_OBJECT

End Function


Function jsArray

  Set jsArray = new jsCore

  jsArray.Kind = JSON_ARRAY

End Function


Function toJSON(val)

  toJSON = (new jsCore).toJSON(val)

End Function

%>


類庫提供了兩種js類型,object和array,使用方法如下:

Set hash = jsObject() '如果要輸出array就寫Set hash=jsArray()

hash("error") = 0

hash("url") = fileUrl

hash.Flush

Response.End

輸出的就是json格式的字符串了


該文章在 2024/12/12 17:58:24 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved