Address Validation API
Validate addresses with Shipium's Address Validation API.
Get started
To use the Address Validation API, you can follow the instructions on this page. Information about address validation within the Shipium platform can be found in the Address Validation documentation.
Verify addresses with the Address Validation API
The Shipium Address Validation API assumes you're using one of the authentication mechanisms detailed in our authentication documentation. The endpoint for Address Validation API calls is included in the table below.
API type | API endpoint |
---|---|
POST | https://api.shipium.com/api/v1/address/validate |
Authentication for API Calls
In the cURL example on this page, the environment variable
AUTHSTRING
is used to handle authorization. The recipe below shows how to set it correctly for both API Key and OAuth users.
The following table provides the required and optional fields for calling the Address Validation API. You can find additional support in the Address Validation API Reference.
Request field | Required/Optional | Field properties | Description |
---|---|---|---|
address.street1 | Required | String Ex.: 123 Main St. | The first address line |
address.street2 | Required | String Ex.: Suite 42 | The second address line |
address.city | Required | String Ex.: Albuquerque | The name of the city for the address |
address.state | Required | String Ex.: NM | The 2-character abbreviation of the state for the address |
address.countryCode | Required | String Ex.: US | The 2-character ISO 3166-1 country code for the address |
address.postalCode | Required | String Ex.: 87121 | A country-code-appropriate postal code for the address |
address.addressType | Required | Stringcommercial or residential | The type of location for the address; see the note below about the information provided for this field |
ignoreSecondaryAddressMismatch | Optional | Booleantrue or false | Set to true in order to ignore secondary address mismatches and addresses with extra information, whether provided as a value for street1 or street2 .The default value is false . |
useSimplifiedCarrierValidation | Optional | Booleantrue or false | Set to true in order to ignore street address mismatches. The default value is false . |
includeCandidate | Optional | Booleantrue or false | When true , an address candidate will be included in the response if one is found. |
A note about
"addressType"
If you do not include an
"addressType"
key and value in the"address"
passed in the request, the value of"addressType"
will be populated with the correct value for the address that was passed.Note: if we are unable to determine the address type for this address, it will be populated as
null
.If you do pass an
"addressType"
of either"residential"
or"commercial"
and it is found to be incorrect, then you will receive an error with an"errorCode"
value of"MISMATCH_ADDRESSTYPE"
.If you pass
"addressType"
and it is correct, then you will just see this reflected in theaddress
value returned in the response.If you pass a completely invalid
"addressType"
value (e.g.,"badfaketype"
), then you will receive an"errorCode"
value of"MALFORMED_ADDRESSTYPE"
.
The Address Validation response attributes are defined in the following table.
Response attribute | Description |
---|---|
addressValidationId | A Shipium-generated ID that uniquely identifies this request |
address | The address that is to be validated by the API |
valid | valid will return true if the address is valid and false if not. |
ignoreSecondaryAddressMismatch | Indicates whether the secondary address components were validated |
useSimplifiedCarrierValidation | Indicates whether the street address(es) were validated |
addressProperties | For valid addresses, additional properties of the address are populated here and include: - poBox - a boolean indicating if this address is a U.S. post office box (true ) or not (false ) |
candidate | If the includeCandidate field was set to true in the request, this is the address candidate that most closely matches the requested address. |
details | The details object will only appear if the valid value is false and contains details about why the address is not valid (if available). |
details.[element].errorCode | A short enumeration of the error, such as "INVALID_STREET1". Most error values will be in the form of "INVALID\_{propertyName}" , referencing the propertyName that is invalid from the passed address or "MISSING\_{propertyName}" if a required property is missing. |
details.[element].errorDescription | If there are more details available, the error description will be populated, but will otherwise be an empty string. |
Example cURL call
This example shows a request to validate an address:
curl --request POST \
--url https://api.shipium.com/api/v1/address/validate \
--header 'accept: application/json' \
--header $AUTHSTRING \
--header 'content-type: application/json' \
--data 'INSERT REQUEST BODY FROM BELOW'
Example request body
The following fields should be included in your JSON request.
{
"address": {
"street1": "1600 Pennsylvania Ave NW",
"street2": null,
"city": "Washington",
"state": "DC",
"countryCode": "US",
"postalCode": "20500",
"addressType": "residential"
},
"ignoreSecondaryAddressMismatch": false,
"useSimplifiedCarrierValidation": false,
"includeCandidate": true
}
Response codes
A bad request will result in a 400.
A good request, whether the address is valid or not, will result in a 200 with details about the validation.
Example response body for a VALID address
{
"addressValidationId": "4d9e3ad7-a54b-43a6-92b7-214a8e93d793",
"address": {
"street1": "1600 Pennsylvania Ave NW",
"street2": null,
"city": "Washington",
"state": "DC",
"countryCode": "US",
"postalCode": "20500",
"addressType": "residential"
},
"valid": true,
"ignoreSecondaryAddressMismatch": false,
"useSimplifiedCarrierValidation": false,
"addressProperties": {
"poBox": false
},
"candidate": {
"street1": "1600 Pennsylvania Ave NW",
"street2": null,
"city": "Washington",
"state": "DC",
"countryCode": "US",
"postalCode": "20500",
"addressType": "residential"
}
}
Example response body for an INVALID address
For this example response, an invalid street address was provided (1600 Pennsylvania ST instead of the correct 1600 Pennsylvania Ave NW).
{
"addressValidationId": "fe3244a0-f7d7-4aaa-9d31-85718505a761",
"address": {
"street1": "1600 Pennsylvania ST",
"street2": null,
"city": "Washington",
"state": "DC",
"countryCode": "US",
"postalCode": "20500",
"addressType": "residential"
},
"valid": false,
"ignoreSecondaryAddressMismatch": false,
"useSimplifiedCarrierValidation": false,
"addressProperties": {
"poBox": false
},
"candidate": {
"street1": "1600 Pennsylvania Ave NW",
"street2": null,
"city": "Washington",
"state": "DC",
"countryCode": "US",
"postalCode": "20500",
"addressType": "residential"
},
"details": [
{
"errorCode": "MISMATCH_STREETLINES",
"errorDescription": "The provided street line: 1600 Pennsylvania ST does not match detected: 1600 PENNSYLVANIA AVE NW because street suffix"
}
]
}
Listing of error code values and descriptions
errorCode Value | Description |
---|---|
INVALID_UNKNOWN_REASON | The validation source determined that the address was invalid but returned no additional information. |
MISSING_CITY | A value for the required city field was not provided. |
MISSING_POSTALCODE | A value for the required postalCode field was not provided. |
MISSING_REGION | A value for the required region field was not provided. |
MISSING_STREET1 | A value for the required street1 field was not provided. |
MALFORMED_ADDRESSTYPE | Invalid address type in the call. If provided, addressType must be either commercial or residential. |
MALFORMED_POSTALCODE | The postal code was in an invalid format for the region. For the US, postalCode must be of the format: 12345 or 12345-7890 . |
MISMATCH_ADDRESSTYPE | The addressType provided in the call did not match the addressType of the validated address. |
MISMATCH_POSTALCODE | The postalCode value provided did not match the correct postalCode for this address.Note that we will ignore a city mismatch if the state and postalcode are both correct to handle neighborhood designations. |
MISMATCH_REGION | The provided state or region did not match with the address. |
MISMATCH_REGION_AND_POSTAL | The provided postalCode is not valid for the state or region passed. |
MISMATCH_STREETLINES | The provided street1 /street2 combination has one or more errors, which are detailed in the errorDescription .Additional details are provided about streetlines mismatches in the errorDescription field. Additional details can be found below. |
Listing of MISMATCH_STREETLINES error descriptions
MISMATCH_STREETLINES
contains additional information about the reason for the mismatch due to the larger number of potential issues with these fields.
At the end of the errorDescription
field, there is additional information that can be used to understand the specifics of the issue in order to help you resolve the issue. The format is:
The provided street line {street line} does not match detected: {alternate address} because {reason}.
Resources
Your Shipium team member is available to help along the way. However, you might find these resources helpful:
Updated about 1 month ago