Download Labels
You have two options for downloading labels you've created with ShipStation API:
- Download via URL: Make an HTTP request to download the label in your desired file type from the URLs provided in the
label_downloadobject from the create label response. - Inline labels: If you only intend to download the label in a single format and you know ahead of time which format that is, you can optimize your workflow by eliminating the extra HTTP request to download the label. Instead, you can use the
label_format,label_layout, andlabel_download_typefields to include the full label in the API response.
Option 1: Download via URL
By default, ShipStation provides URLs to download labels in multiple formats, as in this example:
{
"label_id": "se-test-147980607",
"shipment_id": "se-41783999",
"label_format": "pdf",
"label_layout": "4x6",
"label_download": {
"pdf": "https://api.shipstation.com/v2/downloads/6/3TidbpFJOkm4RmWzQ-woyQ/label-147980607.pdf",
"png": "https://api.shipstation.com/v2/downloads/6/3TidbpFJOkm4RmWzQ-woyQ/label-147980607.png",
"zpl": "https://api.shipstation.com/v2/downloads/6/3TidbpFJOkm4RmWzQ-woyQ/label-147980607.zpl",
"href": "https://api.shipstation.com/v2/downloads/6/3TidbpFJOkm4RmWzQ-woyQ/label-147980607.pdf"
}
}The URLs will remain valid for 90 days. If your workflow requires the ability to access these URLs after 90 days, we recommend storing the label images locally.
Public URLs
ShipStation generates a unique authentication token for each label so it can be securely shared and downloaded by your users without exposing your private API key.
Access the label on the command line using curl:
curl -O https://api.shipstation.com/v2/downloads/6/3TidbpFJOkm4RmWzQ-woyQ/label-147980607.pngLabel Rotation
You can rotate the label 90, 180, or 270 degrees by appending ?rotation=:value to the URL.
- Supported for ZPL and PDF formats.
- Valid
rotationvalue forzpllabels are0(default) and180. - Valid
rotationvalues forpdflabels are0(default),90,180, and270.
You can view the rotated image in your web browser using this URL or download it on the command line using curl:
curl -O http://api.shipstation.com/v2/downloads/0/ZRl-cd0SiUykIRo7ukxGfw/label-1042854.pdf?rotation=180You can chain the download and rotation parameters together using an ampersand to rotate the image and download it directly from your browser - rotation=180&download=0
Option 2: Inline Label
With this method, you'll use the label_format, label_layout, and label_download_type properties to include the full label in the API response.
About the Inline Label Properties
Label Format:
- PDF: The Adobe PDF format. This is the default if
label_formatis unspecified. - PNG: A PNG (portable network graphics) image file.
- ZPL: Zebra Programming Language format, which is useful for printing with a Zebra Printer.
Label Layout:
- 4x6: 4 inch by 6 inch label. This is the default if
label_layoutis unspecified. - letter: US Letter size (8.5 inches by 11 inches).
Label Download Type:
url: You will receive URLs to download the label in separate HTTP requests. The URLs will remain valid for 90 days. This is the default iflabel_download_typeis unspecified.inline: You will receive a single, Base64-encoded label as part of the response. No need for a second request to download the label.
Sample Inline Request & Response
This example demonstrates how to use label_format, label_layout, and label_download_type to request a 4x6 PNG label to be included in the API response.
POST /v2/labels HTTP/1.1
Host: api.shipstation.com
API-Key: __YOUR_API_KEY_HERE__
Content-Type: application/json
Content-Length: 1054
{
"label_format": "png",
"label_layout": "4x6",
"label_download_type": "inline",
"shipment": {
"service_code": "usps_priority_mail",
"ship_to": {
"name": "Amanda Miller",
"phone": "555-555-5555",
"address_line1": "525 S Winchester Blvd",
"city_locality": "San Jose",
"state_province": "CA",
"postal_code": "95128",
"country_code": "US",
"address_residential_indicator": "yes"
},
"ship_from": {
"company_name": "Example Corp.",
"name": "John Doe",
"phone": "111-111-1111",
"address_line1": "4009 Marathon Blvd",
"address_line2": "Suite 300",
"city_locality": "Austin",
"state_province": "TX",
"postal_code": "78756",
"country_code": "US",
"address_residential_indicator": "no"
},
"confirmation": "none",
"insurance_provider": "none",
"packages": [
{
"weight": {
"value": 1.0,
"unit": "ounce"
}
}
]
}
}Response
The label_download.href field in the response will be a Data URI, which is a special kind of URL that includes the data inline.
The Data URI has four parts: scheme, media type, encoding type, data
| Name | Examples | Description |
|---|---|---|
| Scheme | Always data: | This just identifies the URL as a Data URI as opposed to other schemes like http: or ftp:. |
| Media Type | application/pdf image/png application/zpl | This is the label's MIME Type, which corresponds to the label_format that you specified when creating the label. |
| Encoding Type | Always base64 | ShipStation always encodes inline labels in Base64 format. |
| Data | A very long Base64 string | This is the actual Base64-encoded label data. Most programming languages include a Base64 decoder as part of their standard library. If your language doesn't, then you may need to use a third-party Base64 decoder. |
{
"label_id": "se-test-147980607",
"shipment_id": "se-41783999",
"label_format": "png",
"label_layout": "4x6",
"label_download": {
"href": ""
}
}