精品秘无码一区二区三区老师-精品秘一区二三区免费雷安-精品蜜桃秘一区二区三区-精品蜜桃秘一区二区三区粉嫩-精品蜜桃一区二区三区-精品蜜臀国产aⅴ一区二区三区

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

asp讀取解析JSON的幾種方法

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

方法一(使用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

主站蜘蛛池模板: 亚洲国产精品第一区二区三 | 日本内射精品一区二区视频 | 亚洲伊人情人综合网站 | 三级片国产免费观看 | 18禁裸男晨勃露j毛网站 | 欧美激情A片一区二三区 | 亚洲欧美在线综合图区 | 中文字幕av一区中文字幕天堂 | 精品国产第一国产综合精品 | 国产 亚洲 中文在线 字幕 | 亚洲国产精品VA在线看黑人 | 日韩成人影片 | 亚洲一区二区三区乱码 | 日韩大片中文字幕免费视频 | 亚偷熟乱区婷婷综合二区 | 日日夜夜免费精品视频天天综合 | 色综合久久久久综合一本到桃花 | 国产极品JK白丝喷白浆羞羞 | 人妻一区二区视频观看 | 亚洲国产日韩中文字幕 | 8090成年在线看片 | 亚洲国产一二三精品无码 | 在线播放一区二区精品产 | 制服丝袜亚洲无 | 人妻视频二区视频 | 久久国产乱子精品免费女 | 国产b站大片永久免费app | 国产特级毛片aaaaaa高潮流水 | 不得不看的极品av作品 | 国产卡一卡2卡3卡乱码 | 亚洲午夜精品成人毛片 | 色欲AV久久综合人妻无码 | 自偷自拍的黄a大片 | 麻豆产精国品一二三产区区 | 亚洲高清网站在 | 无码国产午夜福利片在线观看 | 国语精品91自产拍在线观看 | 亚洲乱码精品久久久久.. | 国产精品va无码免费 | 欲求不满的哺乳期人妻 | 麻豆果冻传媒2025精品传媒一区 |