Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Classic ASP) Adyen HMAC Signature Calculation for Hosted Payment PagesDemonstrates how to do the HMAC Signature Calculation for a hosted payment page (HPP) in Adyen. For a C# ASP.NET Razor Pages example showing the HTML Form with HMAC signature code, see Adyen HMAC Signature Calculation in C# For more information, see https://docs.adyen.com/classic-integration/hosted-payment-pages/hmac-signature-calculation/
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <body> <% ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. strHtml = "<table class=""od""><tr><th>Description</th><th>Quantity</th><th>Amount</th></tr><tr><td>1 Digital Camera</td><td class=""r"">1</td><td class=""r"">100 GBP</td></tr><tr><td class=""b"">Total</td><td class=""r""></td><td class=""b r"">100.00 GBP</td></tr></table>" ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Gzip") set gzip = Server.CreateObject("Chilkat.Gzip") gzOrderData = gzip.CompressStringENC(strHtml,"utf-8","base64") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Xml") set xml = Server.CreateObject("Chilkat.Xml") xml.Tag = "keyValuePairs" xml.NewChild2 "orderData",gzOrderData ' required, The payment deadline; the payment needs to occur within the specified time value. sessionValidity = "2019-08-11T10:30:00Z" xml.NewChild2 "sessionValidity",sessionValidity ' optional. Normally we'll let Adyen automatically know the country based on the IP address. ' By default, the payment methods offered to a shopper are filtered based on the country the shopper's IP address is mapped to. ' In this way, shoppers are not offered payment methods that are not available in the country they are carrying out the transaction from. ' This IP-to-country mapping is not 100% accurate, so if you have already established the country of the shopper, you can set it explicitly ' in the countryCode parameter. countryCode = "GB" xml.NewChild2 "countryCode",countryCode ' optional shopperLocale = "en_GB" ' If not specified, the locale preference is set to en_GB by default. ' When it is not necessary to include the country-specific part, use only the language code. ' For example: it instead of it_IT to set the locale preferences to Italian. xml.NewChild2 "shopperLocale",shopperLocale ' required, A reference to uniquely identify the payment. This reference is used in all communication with you about the payment status. ' We recommend using a unique value per payment; however, it is not a requirement. If you need to provide multiple references for a transaction, ' you can enter them in this field. Separate each reference value with a hyphen character ("-"). This field has a length restriction: ' you can enter max. 80 characters. merchantReference = "paymentTest1234" xml.NewChild2 "merchantReference",merchantReference ' required, The merchant account identifier you want to process the (transaction) request with. merchantAccount = "ChilkatSoftwareIncCOM" xml.NewChild2 "merchantAccount",merchantAccount ' required. 10000 for $100.00 paymentAmount = "10000" xml.NewChild2 "paymentAmount",paymentAmount ' required, The three-character ISO currency code currencyCode = "GBP" xml.NewChild2 "currencyCode",currencyCode ' required. skinCode = "S7uWsvfB" xml.NewChild2 "skinCode",skinCode ' optional, A unique identifier for the shopper, for example, a customer ID. ' We recommend providing this information, as it is used in velocity fraud checks. It is also the key in recurring payments. ' This field is mandatory in recurring payments. shopperReference = "somebody@example.com" xml.NewChild2 "shopperReference",shopperReference ' optional shopperEmail = "somebody@example.com" xml.NewChild2 "shopperEmail",shopperEmail ' optional, An integer value that adds up to the normal fraud score. ' The value can be either a positive or negative integer. xml.NewChild2 "offset","0" ' Apparently this is a required field. shipBeforeDate = "2019-06-04" xml.NewChild2 "shipBeforeDate",shipBeforeDate xml.SortByTag 1 ' Encode... ' "\" (backslash) as "\\" ' ":" (colon) as "\:" ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbTags = Server.CreateObject("Chilkat.StringBuilder") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbValues = Server.CreateObject("Chilkat.StringBuilder") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbContent = Server.CreateObject("Chilkat.StringBuilder") n = xml.NumChildren i = 0 Do While i < n If (i > 0) Then success = sbTags.Append(":") success = sbValues.Append(":") End If success = xml.GetChild2(i) success = sbTags.Append(xml.Tag) success = sbContent.SetString(xml.Content) numReplaced = sbContent.Replace("\","\\") numReplaced = sbContent.Replace(":","\:") success = sbValues.AppendSb(sbContent) success = xml.GetParent2() i = i + 1 Loop ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbSigningStr = Server.CreateObject("Chilkat.StringBuilder") success = sbSigningStr.AppendSb(sbTags) success = sbSigningStr.Append(":") success = sbSigningStr.AppendSb(sbValues) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Crypt2") set crypt = Server.CreateObject("Chilkat.Crypt2") crypt.HashAlgorithm = "sha256" crypt.MacAlgorithm = "hmac" hmacKey = "934D1E806DDD99595EB430076FD7F8E4D12D0A3F51243A4C0C3897703118E739" success = crypt.SetMacKeyEncoded(hmacKey,"hex") crypt.EncodingMode = "base64" merchantSig = crypt.HmacStringENC(sbSigningStr.GetAsString()) Response.Write "<pre>" & Server.HTMLEncode( merchantSig) & "</pre>" %> </body> </html> |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.