0

我正在使用 Request.ServerVariables 从经典 asp 中的 GoCardless 获取 webhook 响应,它正在调用我的服务器上的页面 http://www.example.com/webhook.asp

我在 webhook.asp 中的代码:

For Each var in Request.ServerVariables 
    WriteLog var & " = " & Request.ServerVariables(var) , "gocardless"
Next 

输出没问题,我可以阅读

Content-Length: 353
Content-Type: application/json
Accept: */*
Accept-Encoding: gzip;q=1.0,deflate;q=0.6,identity;q=0.3
Host: admin.controle-reglementaire.fr
User-Agent: gocardless-webhook-service/1.1
Origin: https://api.gocardless.com
Webhook-Signature: 71ef0f915569e082f090f5150fdf4144be4fed242b1253ad620544c4dd8d615a

我的代码工作正常,但无法检索随附的 json

我必须获得完整的响应信息,如 Gocardless 指南中所示

Originhttps://api.gocardless.com
User-Agentgocardless-webhook-service/1.1
Content-Typeapplication/json
Webhook-Signature71ef0f915569e082f090f5150fdf4144be4fed242b1253ad620544c4dd8d615a
Corps
{
  "events": [
    {
      "id": "EVTESTC4TEBZP2",
      "created_at": "2019-12-21T10:18:30.168Z",
      "resource_type": "payments",
      "action": "failed",
      "links": {
        "payment": "index_ID_123"
      },
      "details": {
        "origin": "bank",
        "cause": "insufficient_funds",
        "scheme": "sepa_core",
        "reason_code": "AM04",
        "description": "The customer's account had insufficient funds to make this payment."
      },
      "metadata": {}
    }
  ]
}

我应该添加什么代码来获取位于标头中的 json 响应

谢谢

4

2 回答 2

0

好的,谢谢大家的帮助,但这是帮助解决我的问题的完整解决方案,效果很好

<!-- #include file="aspJSON1.17.asp"-->
<%

dim filename : filename = Request.ServerVariables("HTTP_Webhook-Signature")
'response.write "filename = " & filename
'---------------------------------------------------------------------------------------------------
Dim lngBytesCount, bstring
If Request.TotalBytes > 0 Then
    lngBytesCount = Request.TotalBytes
    response.ContentType = "application/json;charset=UTF-8"
    bstring= BytesToStr(Request.BinaryRead(lngBytesCount))
    'response.Clear
end if
'response.write bstring
'---------------------------------------------------------------------------------------------------
WriteLog bstring , filename
'---------------------------------------------------------------------------------------------------


Set oJSON = New aspJSON
    oJSON.loadJSON bstring
    For Each record In oJSON.data("events")
        Set this = oJSON.data("events").item(record)
        Response.Write "<p>" & this.item("id") '& " | " & this.item("charge_date") & " | " & this.item("amount") & " | " & this.item("description") & " | " & this.item("status") & " | " & this.item("links")("mandate") & " | " & this.item("links")("subscription") & "<p>"
    Next
Set oJSON = Nothing


'---------------------------------------------------------------------------------------------------
Function BytesToStr(bytes)
    Dim Stream
    Set Stream = Server.CreateObject("Adodb.Stream")
        Stream.Type = 1 'adTypeBinary
        Stream.Open
        Stream.Write bytes
        Stream.Position = 0
        Stream.Type = 2 'adTypeText
        Stream.Charset = "UTF-8"
        BytesToStr = Stream.ReadText
        try = BytesToStr
        Stream.Close
    Set Stream = Nothing
End Function
'---------------------------------------------------------------------------------------------------
sub WriteLog(LogInfo, FileName)
dim  FSO, Inf, dir, Fnm
Set FSO = Server.CreateObject("Scripting.FileSystemObject")
    dir = "D:\webserver\experthost\trace"
    Fnm = dir & "\" & FileName & ".json"
    ' Ouverture du fichier
    ' Fnm : nom du fichier
    ' 8 : mode append
    ' true : le fichier est crée s'il n'existe pas
    set inF = FSO.OpenTextFile(Fnm,2,true)
    '*******************************************
    inF.writeLine LogInfo
    inF.close
    set inF = nothing
end sub

%>
于 2019-12-23T12:32:57.927 回答
0

经过超过 48 小时的谷歌搜索,这解决了我的问题

Dim lngBytesCount, bstring

If Request.TotalBytes > 0 Then
    lngBytesCount = Request.TotalBytes
    bstring= BytesToStr(Request.BinaryRead(lngBytesCount))
    response.Clear
    WriteLog bstring , "gocardless"
end if

Function BytesToStr(bytes)
        Dim Stream
        Set Stream = Server.CreateObject("Adodb.Stream")
            Stream.Type = 1 'adTypeBinary
            Stream.Open
            Stream.Write bytes
            Stream.Position = 0
            Stream.Type = 2 'adTypeText
            Stream.Charset = "UTF-8"
            BytesToStr = Stream.ReadText
            try = BytesToStr
            Stream.Close
        Set Stream = Nothing
    End Function
于 2019-12-22T17:15:05.763 回答