Stuck on integration? Have a question? The developer is standing by.

USPS Tracking API

WhereParcelの統合追跡APIでUSPS荷物を追跡。Priority Mail、First-Classなど全USPSサービスに対応。

クイックスタート

USPSの荷物を1回のAPI呼び出しで追跡:

curl -X POST https://api.whereparcel.com/v2/track \
  -H "Authorization: Bearer YOUR_API_KEY:YOUR_SECRET_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "trackingItems": [{
      "carrier": "us.usps",
      "trackingNumber": "9400111899223456789012"
    }]
  }'

USPS 追跡番号フォーマット

サービスフォーマット
Priority Mail9400 1118 9922 3XXX XXXX XX9400111899223456789012
First-Class Package9205 5XXX XXXX XXXX XXXX XX9205590164917312345671
Priority Mail InternationalECXX XXXX XXXX USEC123456789US

コード例

JavaScript / Node.js

const response = await fetch('https://api.whereparcel.com/v2/track', {
  method: 'POST',
  headers: {
    'Authorization': `Bearer ${API_KEY}:${SECRET_KEY}`,
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    trackingItems: [{
      carrier: 'us.usps',
      trackingNumber: '9400111899223456789012',
    }],
  }),
});

const data = await response.json();
console.log(data.trackingItems[0].status);
// → "in_transit", "delivered", etc.

Python

import requests

response = requests.post(
    'https://api.whereparcel.com/v2/track',
    headers={
        'Authorization': f'Bearer {API_KEY}:{SECRET_KEY}',
        'Content-Type': 'application/json',
    },
    json={
        'trackingItems': [{
            'carrier': 'us.usps',
            'trackingNumber': '9400111899223456789012',
        }],
    },
)

data = response.json()
print(data['trackingItems'][0]['status'])

Webhookでリアルタイム更新

ポーリングの代わりにWebhookを登録して、USPSのステータス更新を自動的に受信しましょう。追跡番号1件あたり1リクエストのみカウントされます。

// Webhookエンドポイントを登録
await fetch('https://api.whereparcel.com/v2/webhook-endpoints', {
  method: 'POST',
  headers: {
    'Authorization': `Bearer ${API_KEY}:${SECRET_KEY}`,
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    url: 'https://yourapp.com/webhooks/tracking',
    description: 'USPS tracking updates',
  }),
});