- Get link
- X
- Other Apps
Amazon Product API is a set of web services that are available for developers, to interact with Amazon e-commerce website (more details are available on Amazon website):
Bellow I'm going to show a simple example on how to use this API:
data:image/s3,"s3://crabby-images/773d7/773d76d79b44ac34d25ecae60b31ccfea46879d1" alt=""
Add service reference (http://webservices.amazon.com/AWSECommerceService/AWSECommerceService.wsdl):
Show all files:
- You can extract information about product: Get information about products, reviews, information about the company selling these items.
- Create a fully functional shopping cart
Bellow I'm going to show a simple example on how to use this API:
Pre-requisites:
Before coding you can try the web client provided by amazon: Product Advertising API Scratchpad
Using the API:
Now we can start coding. For this example I'm just going to create console app that calls the web service to retrieve some information:
1. List products for a given category
2. Get Prices for each product
1. Prepare the project:
Create a new console app:data:image/s3,"s3://crabby-images/773d7/773d76d79b44ac34d25ecae60b31ccfea46879d1" alt=""
Add service reference (http://webservices.amazon.com/AWSECommerceService/AWSECommerceService.wsdl):
Show all files:
3. Add Authentication logic:
Amazon rely on a hashing function to authenticate users of the web service:
Each client is assigned an identifier (access key) and a secret key (Known by the user and amazon only, communicated only once). Communication steps:
1. The user sends a hash of a specific section of the header (this the signature) alongside the access key, the hash function uses the secret key.
1. The user sends a hash of a specific section of the header (this the signature) alongside the access key, the hash function uses the secret key.
2. When the request is received by amazon web service it will extract the secret key corresponding to the requests access key, and hash the header and compare it to the request signature.
This a brief description, more details available on Amazon's website: (This code is inspired from the implementation available at this link)
1. Add IEndPointBehavior Implementation:
public class AmazonSigningEndpointBehavior : IEndpointBehavior { private string accessKeyId = ""; private string secretKey = ""; public AmazonSigningEndpointBehavior(string accessKeyId, string secretKey) { this.accessKeyId = accessKeyId; this.secretKey = secretKey; } public void ApplyClientBehavior(ServiceEndpoint serviceEndpoint, ClientRuntime clientRuntime) { clientRuntime.MessageInspectors.Add(new AmazonSigningMessageInspector(accessKeyId, secretKey)); } public void ApplyDispatchBehavior(ServiceEndpoint serviceEndpoint, EndpointDispatcher endpointDispatcher) { return; } public void Validate(ServiceEndpoint serviceEndpoint) { return; } public void AddBindingParameters(ServiceEndpoint serviceEndpoint, BindingParameterCollection bindingParameters) { return; } }
2. Add Header Class:
public class AmazonHeader : MessageHeader { private string name; private string value; public AmazonHeader(string name, string value) { this.name = name; this.value = value; } public override string Name { get { return name; } } public override string Namespace { get { return "http://security.amazonaws.com/doc/2007-01-01/"; } } protected override void OnWriteHeaderContents(XmlDictionaryWriter xmlDictionaryWriter, MessageVersion messageVersion) { xmlDictionaryWriter.WriteString(value); } }
3. Add Message Inspector:
public class AmazonSigningMessageInspector : IClientMessageInspector { private string accessKeyId = ""; private string secretKey = ""; public AmazonSigningMessageInspector(string accessKeyId, string secretKey) { this.accessKeyId = accessKeyId; this.secretKey = secretKey; } public object BeforeSendRequest(ref Message request, IClientChannel channel) { // prepare the data to sign string operation = Regex.Match(request.Headers.Action, "[^/]+$").ToString(); DateTime now = DateTime.UtcNow; string timestamp = now.ToString("yyyy-MM-ddTHH:mm:ssZ"); string signMe = operation + timestamp; byte[] bytesToSign = Encoding.UTF8.GetBytes(signMe); // sign the data byte[] secretKeyBytes = Encoding.UTF8.GetBytes(secretKey); HMAC hmacSha256 = new HMACSHA256(secretKeyBytes); byte[] hashBytes = hmacSha256.ComputeHash(bytesToSign); string signature = Convert.ToBase64String(hashBytes); // add the signature information to the request headers request.Headers.Add(new AmazonHeader("AWSAccessKeyId", accessKeyId)); request.Headers.Add(new AmazonHeader("Timestamp", timestamp)); request.Headers.Add(new AmazonHeader("Signature", signature)); return null; } public void AfterReceiveReply(ref Message reply, object correlationState) { } }
4. Client Code:
In this code we're using the ItemSearch method.Each ItemSearch require a combination of parameters, in this case I'm using search index and browse node:
PCHardware 340832031 (Computers), the reference is available in amazon website.
Response group specifies the type information you want the webservice to return, for more details check the reference.
static void Main(string[] args) { AWSECommerceServicePortTypeClient srv = new AWSECommerceServicePortTypeClient("AWSECommerceServicePortUK"); string accessKeyId = "Your access key"; string secretKey = "Your Secret Key"; string[] _responseGroup = new string[] { "ItemIds", "OfferSummary", "ItemAttributes" }; srv.ChannelFactory.Endpoint.EndpointBehaviors.Add(new AmazonSigningEndpointBehavior(accessKeyId, secretKey)); var response = srv.ItemSearch(new ItemSearch { AWSAccessKeyId = "Your Access Key", AssociateTag = "associate tag", Request = new ItemSearchRequest[] { new ItemSearchRequest { SearchIndex = "PCHardware", BrowseNode = "340832031", ResponseGroup = _responseGroup, }}, }); }If you run the client code it will fail, one more step is left, where we need to fix the auto generated code of the webservice proxy.
One way to do it is to search for all occurrences of ImageSet[][] and replace it by ImageSet[].
Comments
Post a Comment