Last updated

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_download object 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, and label_download_type fields 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.

You can download the label in your web browser by appending ?download=0 to the URL, or you download it on the command line using curl:

curl -O https://api.shipstation.com/v2/downloads/6/3TidbpFJOkm4RmWzQ-woyQ/label-147980607.png

Label 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 rotation value for zpl labels are 0 (default) and 180.
  • Valid rotation values for pdf labels are 0 (default), 90, 180, and 270.

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=180

You 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_format is 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_layout is 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 if label_download_type is 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

NameExamplesDescription
SchemeAlways data:This just identifies the URL as a Data URI as opposed to other schemes like http: or ftp:.
Media Typeapplication/pdf image/png application/zplThis is the label's MIME Type, which corresponds to the label_format that you specified when creating the label.
Encoding TypeAlways base64ShipStation always encodes inline labels in Base64 format.
DataA very long Base64 stringThis 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": ""
 }
}