Classic ASP
Classic ASP
Amazon SP-API Get Order Items
See more Amazon SP-API Examples
Returns detailed order item information for the order that you specify.Chilkat Classic ASP Downloads
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
' Gets detailed order item information for a specified order ID
' The order ID is something like "902-1845936-5435065" and it is the AmazonOrderId returned in the JSON when getting the list of orders. For example:
' {
' "payload": {
' "CreatedBefore": "1.569521782042E9",
' "Orders": [
' {
' "AmazonOrderId": "902-1845936-5435065",
' "PurchaseDate": "1970-01-19T03:58:30Z",
' ...
' However, when using the sandbox, instead use the explicit keyword TEST_CASE_200
orderId = "TEST_CASE_200"
set authAws = Server.CreateObject("Chilkat.AuthAws")
authAws.AccessKey = "AWS_ACCESS_KEY"
authAws.SecretKey = "AWS_SECRET_KEY"
authAws.ServiceName = "execute-api"
' Use the region that is correct for your needs.
authAws.Region = "eu-west-1"
' First get a restricted data token for the given order ID.
' This requires an LWA access token which cannot be more than 1 hour old.
' See Fetch SP-API LWA Access Token
set jsonLwaToken = Server.CreateObject("Chilkat.JsonObject")
success = jsonLwaToken.LoadFile("qa_data/tokens/sp_api_lwa_token.json")
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( "Failed to load LWA access token.") & "</pre>"
Response.End
End If
' Must use the non-sandbox domain for getting the RDT.
set rest = Server.CreateObject("Chilkat.Rest")
success = rest.Connect("sellingpartnerapi-eu.amazon.com",443,1,1)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
Response.End
End If
success = rest.SetAuthAws(authAws)
' Add the x-amz-access-token request header.
lwa_token = jsonLwaToken.StringOf("access_token")
success = rest.ClearAllHeaders()
success = rest.AddHeader("x-amz-access-token",lwa_token)
' We're going to send a POST with the following JSON body:
' {
' "restrictedResources": [
' {
' "method": "GET",
' "path": "/orders/v0/orders/{orderId}/orderItems",
' "dataElements": ["buyerInfo"]
' }
' ]
' }
set sbPath = Server.CreateObject("Chilkat.StringBuilder")
success = sbPath.Append("/orders/v0/orders/")
success = sbPath.Append(orderId)
success = sbPath.Append("/orderItems")
set jsonRc = Server.CreateObject("Chilkat.JsonObject")
success = jsonRc.UpdateString("restrictedResources[0].method","GET")
success = jsonRc.UpdateString("restrictedResources[0].path",sbPath.GetAsString())
success = jsonRc.UpdateString("restrictedResources[0].dataElements[0]","buyerInfo")
set sbRequest = Server.CreateObject("Chilkat.StringBuilder")
success = jsonRc.EmitSb(sbRequest)
set sbResponse = Server.CreateObject("Chilkat.StringBuilder")
uri = "/tokens/2021-03-01/restrictedDataToken"
success = rest.FullRequestSb("POST",uri,sbRequest,sbResponse)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
Response.End
End If
' Examine the response status.
statusCode = rest.ResponseStatusCode
If (statusCode <> 200) Then
Response.Write "<pre>" & Server.HTMLEncode( "Response status code: " & statusCode) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response status text: " & rest.ResponseStatusText) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response body: ") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( sbResponse.GetAsString()) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Failed.") & "</pre>"
Response.End
End If
' Get the restricted data token.
set jsonResp = Server.CreateObject("Chilkat.JsonObject")
success = jsonResp.LoadSb(sbResponse)
restrictedDataToken = jsonResp.StringOf("restrictedDataToken")
Response.Write "<pre>" & Server.HTMLEncode( "Restricted Data Token: " & restrictedDataToken) & "</pre>"
' ------------------------------------------------------------------------------------------------------------
' ------------------------------------------------------------------------------------------------------------
' Now that we have the RDT, we can use it to get information about the order.
'
' Yes, the SP-API is horribly tedious and painful. You must use an RDT specifically tailored to each request requiring an RDT,
' the RDT must not be over an hour old, and if you need to get a new RDT you must get it using an LWA token that itself is not
' more than an hour old. If the LWA is more than an hour old, you must get a new one. Ughhh!!!!!
' ------------------------------------------------------------------------------------------------------------
' Disconnect from the non-sandbox domain. This example will use the sandbox.
' (The RDT was obtained using the non-sandbox domain. For some reason, the sandbox domain does not work for getting the RDT.)
success = rest.Disconnect(100)
success = rest.Connect("sandbox.sellingpartnerapi-eu.amazon.com",443,1,1)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
Response.End
End If
success = rest.SetAuthAws(authAws)
success = rest.ClearAllHeaders()
success = rest.AddHeader("x-amz-access-token",restrictedDataToken)
success = rest.ClearAllQueryParams()
success = rest.AddQueryParam("MarketplaceIds","ATVPDKIKX0DER")
success = rest.ClearAllPathParams()
success = rest.AddPathParam("{orderId}",orderId)
uri = "/orders/v0/orders/{orderId}/orderItems"
success = rest.FullRequestNoBodySb("GET",uri,sbResponse)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
Response.End
End If
' Examine the response status.
statusCode = rest.ResponseStatusCode
If (statusCode <> 200) Then
Response.Write "<pre>" & Server.HTMLEncode( "Response status text: " & rest.ResponseStatusText) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response body: ") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( sbResponse.GetAsString()) & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Failed.") & "</pre>"
Response.End
End If
' If successful, gets a JSON response such as the following:
' {
' "payload": {
' "AmazonOrderId": "902-1845936-5435065",
' "OrderItems": [
' {
' "ASIN": "B00551Q3CS",
' "OrderItemId": "05015851154158",
' "SellerSKU": "NABetaASINB00551Q3CS",
' "Title": "B00551Q3CS [Card Book]",
' "QuantityOrdered": 1,
' "QuantityShipped": 0,
' "ProductInfo": {
' "NumberOfItems": 1
' },
' "ItemPrice": {
' "CurrencyCode": "USD",
' "Amount": "10.00"
' },
' "ItemTax": {
' "CurrencyCode": "USD",
' "Amount": "1.01"
' },
' "PromotionDiscount": {
' "CurrencyCode": "USD",
' "Amount": "0.00"
' },
' "IsGift": false,
' "ConditionId": "New",
' "ConditionSubtypeId": "New",
' "IsTransparency": false,
' "SerialNumberRequired": false,
' "IossNumber": "",
' "DeemedResellerCategory": "IOSS",
' "StoreChainStoreId": "ISPU_StoreId",
' "BuyerRequestedCancel": {
' "IsBuyerRequestedCancel": true,
' "BuyerCancelReason": "Found cheaper somewhere else."
' }
' }
' ]
' }
' }
' Use this online tool to generate parsing code from sample JSON:
' Generate Parsing Code from JSON
set json = Server.CreateObject("Chilkat.JsonObject")
success = json.LoadSb(sbResponse)
json.EmitCompact = 0
Response.Write "<pre>" & Server.HTMLEncode( json.Emit()) & "</pre>"
AmazonOrderId = json.StringOf("payload.AmazonOrderId")
i = 0
count_i = json.SizeOfArray("payload.OrderItems")
Do While i < count_i
json.I = i
ASIN = json.StringOf("payload.OrderItems[i].ASIN")
OrderItemId = json.StringOf("payload.OrderItems[i].OrderItemId")
SellerSKU = json.StringOf("payload.OrderItems[i].SellerSKU")
Title = json.StringOf("payload.OrderItems[i].Title")
QuantityOrdered = json.IntOf("payload.OrderItems[i].QuantityOrdered")
QuantityShipped = json.IntOf("payload.OrderItems[i].QuantityShipped")
NumberOfItems = json.IntOf("payload.OrderItems[i].ProductInfo.NumberOfItems")
CurrencyCode = json.StringOf("payload.OrderItems[i].ItemPrice.CurrencyCode")
Amount = json.StringOf("payload.OrderItems[i].ItemPrice.Amount")
ItemTaxCurrencyCode = json.StringOf("payload.OrderItems[i].ItemTax.CurrencyCode")
ItemTaxAmount = json.StringOf("payload.OrderItems[i].ItemTax.Amount")
PromotionDiscountCurrencyCode = json.StringOf("payload.OrderItems[i].PromotionDiscount.CurrencyCode")
PromotionDiscountAmount = json.StringOf("payload.OrderItems[i].PromotionDiscount.Amount")
IsGift = json.BoolOf("payload.OrderItems[i].IsGift")
ConditionId = json.StringOf("payload.OrderItems[i].ConditionId")
ConditionSubtypeId = json.StringOf("payload.OrderItems[i].ConditionSubtypeId")
IsTransparency = json.BoolOf("payload.OrderItems[i].IsTransparency")
SerialNumberRequired = json.BoolOf("payload.OrderItems[i].SerialNumberRequired")
IossNumber = json.StringOf("payload.OrderItems[i].IossNumber")
DeemedResellerCategory = json.StringOf("payload.OrderItems[i].DeemedResellerCategory")
StoreChainStoreId = json.StringOf("payload.OrderItems[i].StoreChainStoreId")
IsBuyerRequestedCancel = json.BoolOf("payload.OrderItems[i].BuyerRequestedCancel.IsBuyerRequestedCancel")
BuyerCancelReason = json.StringOf("payload.OrderItems[i].BuyerRequestedCancel.BuyerCancelReason")
i = i + 1
Loop
Response.Write "<pre>" & Server.HTMLEncode( "Success!") & "</pre>"
%>
</body>
</html>