申請プロセス
APIを使用するには、まず AI証明写真制作 API の該当ページでサービスを申請する必要があります。ページに入ったら、「Acquire」ボタンをクリックします。以下の図のように:
まだログインまたは登録していない場合は、自動的にログインページにリダイレクトされ、登録とログインを促されます。ログインまたは登録後、現在のページに自動的に戻ります。
初回申請時には無料のクレジットが付与され、このAPIを無料で使用できます。
基本使用
まず、基本的な使用方法を理解します。処理したい人像画像と好みのAI証明写真テンプレートを入力することで、処理後の結果を得ることができます。最初に、image_urls フィールドを簡単に渡す必要があります。これは、処理したい人像画像のリンクの配列です。以下の図のように:

mode を指定することもできます。一般的には、遅い relax と速い fast の2種類に分かれています。具体的な内容は以下の通りです:

accept:受け取りたいレスポンスの形式。ここではapplication/json、つまりJSON形式を記入します。authorization:APIを呼び出すためのキー。申請後、直接ドロップダウンから選択できます。
mode:証明写真生成のチャンネル。主にfast(速い)とrelax(遅い)の2種類があります。relaxを使用する場合は、以下のパラメータcallback_urlの使用を強く推奨します。template:証明写真テンプレートのスタイル。image_urls:アップロードする証明写真の人像リンク。callback_url:結果を返すためのURL。

success:この時点での証明写真生成タスクの状態。task_id:この時点での証明写真生成タスクID。data:この時点での証明写真生成タスクの結果リスト。id:この時点での証明写真生成タスクの写真ID。image_url:この時点での証明写真生成タスクの画像リンク。template:この時点での証明写真生成タスクの証明写真テンプレート名。
data の画像リンクアドレスに従って証明写真を取得するだけです。
また、対応する接続コードを生成したい場合は、生成されたものを直接コピーできます。例えば、CURLのコードは以下の通りです:
非同期コールバック
AI証明写真生成の時間は比較的長く、約1-2分かかります。APIが長時間応答しない場合、HTTPリクエストは接続を維持し続け、追加のシステムリソースを消費する可能性があります。そのため、本APIは非同期コールバックのサポートも提供しています。 全体の流れは、クライアントがリクエストを発起する際に、追加でcallback_url フィールドを指定します。クライアントがAPIリクエストを発起した後、APIはすぐに結果を返し、task_id フィールド情報を含み、現在のタスクIDを示します。タスクが完了すると、生成された証明写真の結果がPOST JSON形式でクライアントが指定した callback_url に送信され、その中にも task_id フィールドが含まれます。これにより、タスク結果をIDで関連付けることができます。
以下の例を通じて、具体的にどのように操作するかを理解しましょう。
まず、WebhookコールバックはHTTPリクエストを受け取ることができるサービスで、開発者は自分が構築したHTTPサーバーのURLに置き換える必要があります。ここでは、便利なデモのために公開されたWebhookサンプルサイト https://webhook.site/ を使用します。このサイトを開くとWebhook URLが得られます。以下の図のように:
このURLをコピーすればWebhookとして使用できます。このサンプルは https://webhook.site/00f38b26-4289-4899-83d6-0cea7308850a です。
次に、フィールド callback_url を上記のWebhook URLに設定し、人像画像リンクとテンプレートを入力します。本文では、パラメータ mode が relax の場合に非同期コールバックを使用することを推奨します。具体的な内容は以下の図のように:

https://webhook.site/00f38b26-4289-4899-83d6-0cea7308850a で生成された結果を確認できます。以下の図のように:
内容如下:
task_id フィールドが含まれており、他のフィールドは前述の内容と類似しており、このフィールドを通じてタスクの関連付けが可能です。
エラーハンドリング
APIを呼び出す際にエラーが発生した場合、APIは対応するエラーコードとメッセージを返します。例えば:400 token_mismatched:不正なリクエスト、パラメータが欠落または無効である可能性があります。400 api_not_implemented:不正なリクエスト、パラメータが欠落または無効である可能性があります。401 invalid_token:未認証、無効または欠落した認証トークン。429 too_many_requests:リクエストが多すぎます、レート制限を超えました。500 api_error:内部サーバーエラー、サーバーで何かがうまくいきませんでした。

