Java
Java
Walmart Partner API Authentication (Generate a Signature for a Request)
See more RSA Examples
Demonstrates how to generate a signature for a Walmart Partner REST API call.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
String consumerId = "b68d2a72....";
String baseUrl = "https://marketplace.walmartapis.com/v2/feeds";
// This is your Base64 encoded private key
String privateEncodedStr = "MIICeAIBADANBgkqhkiG9w0BAQEFAA......";
String httpMethod = "GET";
// We need a timestamp in decimal string form representing the number of milliseconds since Jan 01 1970 UTC.
CkDateTime dt = new CkDateTime();
// Set bLocal = true for a timestamp in the local timezone. Set bLocal = false for a UTC timestamp.
boolean bLocal = false;
// This gets the timestamp in seconds, not milliseconds.
int timeStampVal = dt.GetAsUnixTime(bLocal);
// Build the string to sign.
CkStringBuilder sbStringToSign = new CkStringBuilder();
sbStringToSign.Append(consumerId);
sbStringToSign.Append("\n");
sbStringToSign.Append(baseUrl);
sbStringToSign.Append("\n");
sbStringToSign.Append(httpMethod);
sbStringToSign.Append("\n");
sbStringToSign.AppendInt(timeStampVal);
// We add three zero's so that the timestamp value is in milliseconds.
// We don't care about accuracy down to less than a second.
// All the server cares about is that the request was signed at the current date/time
// within some reasonable margin of error (to account for systems having clocks
// that may be slightly different).
sbStringToSign.Append("000\n");
CkPrivateKey privKey = new CkPrivateKey();
// Load the private key into a private key object.
// Note: Technically the private key is not PEM because it lacks the header/footer strings
// used for PEM. However, the LoadPem method will still accept it and load it correctly.
success = privKey.LoadPem(privateEncodedStr);
if (success == false) {
System.out.println(privKey.lastErrorText());
return;
}
CkRsa rsa = new CkRsa();
success = rsa.UsePrivateKey(privKey);
if (success == false) {
System.out.println(rsa.lastErrorText());
return;
}
// We want a base64 signature string.
rsa.put_EncodingMode("base64");
String signatureString = rsa.signStringENC(sbStringToSign.getAsString(),"SHA256");
if (rsa.get_LastMethodSuccess() == false) {
System.out.println(rsa.lastErrorText());
return;
}
System.out.println("Signature String: " + signatureString);
}
}