Android™
Android™
REST URL Encode Path Parts and Query Params
See more REST Examples
When passing a path to a Chilkat REST function, the path parts and query params should be URL encoded. This example explains..Chilkat Android™ Downloads
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;
import android.app.Activity;
import com.chilkatsoft.*;
import android.widget.TextView;
import android.os.Bundle;
public class SimpleActivity extends Activity {
private static final String TAG = "Chilkat";
// Called when the activity is first created.
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
boolean success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// This example demonstrates how to URL encode the path passed to a REST function.
// It is demonstrated with an Amazon SP API GET request to get details about a listings item for a selling partner.
// See https://developer-docs.amazon.com/sp-api/docs/listings-items-api-v2021-08-01-reference#getlistingsitem
CkRest rest = new CkRest();
// Connect to the REST server.
boolean bTls = true;
int port = 443;
boolean bAutoReconnect = true;
success = rest.Connect("sellingpartnerapi-eu.amazon.com",port,bTls,bAutoReconnect);
rest.ClearAllQueryParams();
rest.AddQueryParam("marketplaceids","XYZABC123");
rest.AddQueryParam("includedData","offers");
rest.AddHeader("x-amz-access-token","YOUR_ACCESS_TOKEN");
CkAuthAws authAws = new CkAuthAws();
authAws.put_AccessKey("YOUR_AWS_APP_ID");
authAws.put_SecretKey("YOUR_AWS_APP_SECRET_KEY");
authAws.put_Region("eu-west-1");
authAws.put_ServiceName("execute-api");
rest.SetAuthAws(authAws);
// The path that is passed to FullRequestNobBody
// Here's a sample path that is not yet URL encoded.
String path = "/listings/2022-07-01/items/ABCDEFGHIJ/100x100_28g_LANCETS(BOXED)";
// The path passed to FullRequestNoBody needs to have the parts URL-encoded.
// The "/" chars are not URL encoded, but the individual path parts should be URL encoded.
// For example: /listings/2022-07-01/items/ABCDEFGHIJ/100x100_28g_LANCETS%28BOXED%29
// In this case, we'll prepare the path like this:
CkStringBuilder sbPath = new CkStringBuilder();
sbPath.Append("100x100_28g_LANCETS(BOXED)");
// URL encode the contents of the sbPath.
sbPath.Encode("url","utf-8");
// Prepend the remaining which does not need to be URL encoded.
sbPath.Prepend("/listings/2022-07-01/items/ABCDEFGHIJ/");
Log.i(TAG, "URL encoded path: " + sbPath.getAsString());
String responseJson = rest.fullRequestNoBody("GET",sbPath.getAsString());
if (rest.get_LastMethodSuccess() != true) {
Log.i(TAG, rest.lastErrorText());
return;
}
Log.i(TAG, responseJson);
Log.i(TAG, "----");
}
static {
System.loadLibrary("chilkat");
// Note: If the incorrect library name is passed to System.loadLibrary,
// then you will see the following error message at application startup:
//"The application <your-application-name> has stopped unexpectedly. Please try again."
}
}