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
(Android™) Shippo Validate Global AddressDemonstrates how to validate a global address. For more information, see https://goshippo.com/docs/address-validation/
// 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); // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttp http = new CkHttp(); boolean success; // Implements the following CURL command: // curl https://api.goshippo.com/addresses/ \ // -H "Authorization: ShippoToken <API_TOKEN>" \ // -d name="Shawn Ippotle" \ // -d company="Shippo" \ // -d street1="Kortrijksesteenweg 1005" \ // -d city="Gent" \ // -d zip=9000 \ // -d country="BE" \ // -d email="shippotle@goshippo.com"\ // -d validate=true CkHttpRequest req = new CkHttpRequest(); req.put_HttpVerb("POST"); req.put_Path("/addresses/"); req.put_ContentType("application/x-www-form-urlencoded"); req.AddParam("name","Shawn Ippotle"); req.AddParam("company","Shippo"); req.AddParam("street1","Kortrijksesteenweg 1005"); req.AddParam("city","Gent"); req.AddParam("zip","9000"); req.AddParam("country","BE"); req.AddParam("email","shippotle@goshippo.com"); req.AddParam("validate","true"); req.AddHeader("Authorization","ShippoToken <API_TOKEN>"); CkHttpResponse resp = http.PostUrlEncoded("https://api.goshippo.com/addresses/",req); if (http.get_LastMethodSuccess() == false) { Log.i(TAG, http.lastErrorText()); return; } CkStringBuilder sbResponseBody = new CkStringBuilder(); resp.GetBodySb(sbResponseBody); CkJsonObject jResp = new CkJsonObject(); jResp.LoadSb(sbResponseBody); jResp.put_EmitCompact(false); Log.i(TAG, "Response Body:"); Log.i(TAG, jResp.emit()); int respStatusCode = resp.get_StatusCode(); Log.i(TAG, "Response Status Code = " + String.valueOf(respStatusCode)); if (respStatusCode >= 400) { Log.i(TAG, "Response Header:"); Log.i(TAG, resp.header()); Log.i(TAG, "Failed."); return; } // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // { // "object_created": "2017-07-26T17:52:37.305Z", // "object_updated": "2017-07-26T17:52:37.351Z", // "object_id": "b7f9709df3914d1ca6efe4c30e7b0572", // "is_complete": true, // "validation_results": { // "is_valid": true, // "messages": [ // { // "source": "Shippo Address Validator", // "type": "address_correction", // "code": "administrative_area_change", // "text": "The administrative area (state or province) was added or changed." // }, // { // "source": "Shippo Address Validator", // "code": "geocoded_rooftop", // "text": "The record was geocoded down to rooftop level, meaning the point is within the property boundaries (most often the center)." // }, // { // "source": "Shippo Address Validator", // "code": "premises_full", // "text": "The address has been verified to the Premise (House or Building) Level, which is the highest level possible with the reference data." // } // ] // }, // "object_owner": "hippo@goshippo.com", // "name": "Hippo Shippo", // "company": "Shippo", // "street_no": "2", // "street1": "Unter den Linden", // "street2": "", // "street3": "", // "city": "Berlin", // "state": "", // "zip": "10117", // "country": "DE", // "longitude": "13.39751", // "latitude": "52.51785", // "phone": "14151234567", // "email": "hippo@goshippo.com", // "is_residential": null, // "metadata": "", // "test": false // } // Sample code for parsing the JSON response... // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON String source; String v_type; String code; String text; String object_created = jResp.stringOf("object_created"); String object_updated = jResp.stringOf("object_updated"); String object_id = jResp.stringOf("object_id"); boolean is_complete = jResp.BoolOf("is_complete"); boolean validation_resultsIs_valid = jResp.BoolOf("validation_results.is_valid"); String object_owner = jResp.stringOf("object_owner"); String name = jResp.stringOf("name"); String company = jResp.stringOf("company"); String street_no = jResp.stringOf("street_no"); String street1 = jResp.stringOf("street1"); String street2 = jResp.stringOf("street2"); String street3 = jResp.stringOf("street3"); String city = jResp.stringOf("city"); String state = jResp.stringOf("state"); String zip = jResp.stringOf("zip"); String country = jResp.stringOf("country"); String longitude = jResp.stringOf("longitude"); String latitude = jResp.stringOf("latitude"); String phone = jResp.stringOf("phone"); String email = jResp.stringOf("email"); String is_residential = jResp.stringOf("is_residential"); String metadata = jResp.stringOf("metadata"); boolean test = jResp.BoolOf("test"); int i = 0; int count_i = jResp.SizeOfArray("validation_results.messages"); while (i < count_i) { jResp.put_I(i); source = jResp.stringOf("validation_results.messages[i].source"); v_type = jResp.stringOf("validation_results.messages[i].type"); code = jResp.stringOf("validation_results.messages[i].code"); text = jResp.stringOf("validation_results.messages[i].text"); i = i + 1; } } 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." } } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.