메인 콘텐츠로 건너뛰기
본 문서에서는 SeeDream 이미지 생성 API 연동 방법을 소개합니다. 이 API는 사용자 정의 매개변수를 입력하여 SeeDream 공식 이미지를 생성할 수 있습니다.

신청 절차

API를 사용하려면 먼저 SeeDream 이미지 생성 API 해당 페이지에서 서비스를 신청해야 합니다. 페이지에 들어가면 “Acquire” 버튼을 클릭합니다. 아래 그림과 같습니다: 로그인 또는 등록이 되어 있지 않으면 자동으로 로그인 페이지로 이동하여 등록 및 로그인을 요청합니다. 로그인 및 등록 후에는 자동으로 현재 페이지로 돌아옵니다. 첫 신청 시 무료 사용량이 제공되며, 이 API를 무료로 사용할 수 있습니다.

기본 사용

먼저 기본 사용 방법을 이해해야 합니다. 즉, 프롬프트 prompt, 생성 동작 action, 이미지 크기 size를 입력하면 처리된 결과를 얻을 수 있습니다. 먼저 간단하게 action 필드를 전달해야 하며, 그 값은 generate입니다. 그런 다음 프롬프트를 입력해야 하며, 구체적인 내용은 다음과 같습니다:

여기서 요청 헤더를 설정한 것을 볼 수 있습니다. 포함된 내용은 다음과 같습니다:
  • accept: 어떤 형식의 응답 결과를 받고 싶은지, 여기서는 application/json으로 작성하여 JSON 형식으로 설정합니다.
  • authorization: API 호출을 위한 키로, 신청 후 드롭다운에서 선택할 수 있습니다.
또한 요청 본문을 설정했습니다. 포함된 내용은 다음과 같습니다:
  • prompt: 프롬프트.
  • model: 생성 모델, 기본값은 doubao-seedream-4.0입니다.
  • image: 입력 이미지 정보로, URL 또는 Base64 인코딩을 지원합니다. 여기서 doubao-seedream-4.5, doubao-seedream-4.0은 단일 이미지 또는 다중 이미지 입력을 지원하며, doubao-seededit-3.0-i2i는 단일 이미지 입력만 지원하고, doubao-seededit-3.0-t2i는 이 매개변수를 지원하지 않습니다.
  • size: 생성할 이미지의 크기 정보를 지정하며, 다음 두 가지 방법을 지원합니다. 혼용할 수 없습니다. 방법 1 | 생성할 이미지의 해상도를 지정하고 프롬프트에서 자연어로 이미지의 가로 세로 비율, 이미지 형태 또는 이미지 용도를 설명합니다. 최종적으로 모델이 이미지 크기를 판단합니다. 방법 2 | 생성할 이미지의 가로 세로 픽셀 값을 지정합니다: 기본값: 2048x2048, 모델에 따라 기본값이 다릅니다.
  • seed: 모델 생성 내용의 무작위성을 제어하는 난수 시드입니다. 값의 범위는 [-1, 2147483647]입니다. 오직 doubao-seedream-3.0-t2i, doubao-seededit-3.0-i2i만 이 매개변수를 지원합니다.
  • sequential_image_generation: 그룹 이미지: 입력한 내용을 기반으로 생성된 관련 이미지 그룹입니다. 오직 doubao-seedream-4.5, doubao-seedream-4.0만 이 매개변수를 지원하며, 기본값은 disabled입니다.
  • stream: 스트리밍 출력 모드를 활성화할지 여부를 제어합니다. 오직 doubao-seedream-4.5, doubao-seedream-4.0만 이 매개변수를 지원하며, 기본값은 false입니다.
  • guidance_scale: 모델 출력 결과와 프롬프트의 일치 정도, 생성 이미지의 자유도, 즉 텍스트 가중치입니다. 값이 클수록 모델의 자유도가 작아지고 사용자 입력의 프롬프트와의 관련성이 강해집니다. 값의 범위: [1, 10]. doubao-seedream-3.0-t2i의 기본값은 2.5, doubao-seededit-3.0-i2i의 기본값은 5.5이며, 다른 모델은 지원하지 않습니다.
  • response_format: 생성된 이미지의 반환 형식을 지정합니다. 기본값은 url이며, b64_json도 지원합니다.
  • watermark: 생성된 이미지에 워터마크를 추가할지 여부입니다. 기본값은 true입니다.
  • callback_url: 결과를 회신받을 URL입니다.
선택 후 오른쪽에서도 해당 코드가 생성된 것을 확인할 수 있습니다. 아래 그림과 같습니다:

“Try” 버튼을 클릭하면 테스트를 진행할 수 있으며, 위 그림과 같이 다음과 같은 결과를 얻을 수 있습니다:
{
  "success": true,
  "task_id": "25027ba3-0430-4a1b-91c8-d2297f19ba73",
  "trace_id": "8043a9e9-692f-43b0-82f7-5890f798be38",
  "data": [
    {
      "prompt": "a white siamese cat",
      "size": "2048x2048",
      "image_url": "https://platform.cdn.acedata.cloud/seedream/3c060029-69b1-406f-a957-fcd55ddc9386.jpg"
    }
  ]
}
반환 결과는 여러 필드로 구성되어 있으며, 설명은 다음과 같습니다:
  • success: 현재 비디오 생성 작업의 상태입니다.
  • task_id: 현재 비디오 생성 작업 ID입니다.
  • trace_id: 현재 비디오 생성 추적 ID입니다.
  • data: 현재 이미지 생성 작업의 결과 목록입니다.
    • image_url: 현재 이미지 생성 작업의 링크입니다.
    • prompt: 프롬프트입니다.
    • size: 생성된 이미지의 픽셀입니다.
만족스러운 이미지 정보를 얻었으며, 결과의 data에서 이미지 링크 주소를 통해 생성된 SeeDream 이미지를 가져올 수 있습니다. 또한, 해당 연동 코드를 생성하고 싶다면 직접 복사하여 사용할 수 있습니다. 예를 들어 CURL의 코드는 다음과 같습니다:
curl -X POST 'https://api.acedata.cloud/seedream/images' \
-H 'accept: application/json' \
-H 'authorization: Bearer ${token}' \
-H 'content-type: application/json' \
-d '{
  "action": "generate",
  "model": "doubao-seedream-4-0-250828",
  "prompt": "a white siamese cat"
}'

이미지 편집 작업

특정 이미지를 편집하고 싶다면, 먼저 매개변수 image에 편집할 이미지 링크를 전달해야 합니다.
  • model: 이번 이미지 편집 작업에 사용되는 모델로, 현재 doubao-seedream-4.5, doubao-seedream-4.0은 단일 이미지 또는 다중 이미지 입력을 지원하며, doubao-seededit-3.0-i2i는 단일 이미지 입력만 지원합니다.
  • image: 편집할 이미지를 업로드합니다. 한 장 또는 여러 장을 지원합니다.
작성 예시는 다음과 같습니다:

해당 코드:
import requests

url = "https://api.acedata.cloud/flux/images"

headers = {
    "accept": "application/json",
    "authorization": "Bearer {token}",
    "content-type": "application/json"
}

payload = {
    "model": "doubao-seedream-4-0-250828",
  "prompt": "모델의 포즈와 액체 의상의 흐르는 형태를 변경하지 않고 유지합니다. 의류 재료를 은색 금속에서 완전히 투명한 물(또는 유리)로 변경합니다. 액체 흐름을 통해 모델 피부의 세부 사항이 보입니다. 빛과 그림자 효과는 반사에서 굴절로 이동합니다.",
  "image": ["https://ark-project.tos-cn-beijing.volces.com/doc_image/seedream4_5_imageToimage.png"],
  "size": "2K",
  "watermark": False
}

response = requests.post(url, json=payload, headers=headers)
print(response.text)
실행 버튼을 클릭하면 즉시 결과를 얻을 수 있습니다.
{
    "success": true,
    "task_id": "c9aaffa2-b8ac-40ff-8468-43e77cb9ddde",
    "trace_id": "131a40c3-2eaf-44c9-af28-c9b408577286",
    "data": [
        {
            "prompt": "모델의 포즈와 액체 의상의 흐르는 형태를 변경하지 마십시오. 의류 재료를 은 금속에서 완전히 투명한 물(또는 유리)로 변경하십시오. 액체 흐름을 통해 모델 피부의 세부 사항이 보입니다. 빛과 그림자 효과는 반사에서 굴절로 전환됩니다.",
            "size": "2048x2048",
            "image_url": "https://platform.cdn.acedata.cloud/seedream/3e88db7e-4771-4f6a-adbd-5ae4590c5d59.jpg"
        }
    ]
}
생성된 효과는 원본 이미지를 편집한 효과로, 결과는 위와 유사합니다.

비동기 콜백

SeeDream Images Generation API의 생성 시간은 상대적으로 길어 약 1-2분이 소요됩니다. API가 오랜 시간 응답하지 않으면 HTTP 요청은 계속 연결을 유지하여 추가 시스템 리소스 소모를 초래하므로, 이 API는 비동기 콜백 지원도 제공합니다. 전체 프로세스는: 클라이언트가 요청을 시작할 때 추가로 callback_url 필드를 지정하고, 클라이언트가 API 요청을 시작한 후 API는 즉시 결과를 반환하며, 현재 작업 ID를 나타내는 task_id 필드 정보를 포함합니다. 작업이 완료되면 생성된 이미지 결과가 POST JSON 형식으로 클라이언트가 지정한 callback_url로 전송되며, 여기에도 task_id 필드가 포함되어 있어 작업 결과를 ID로 연결할 수 있습니다. 아래 예제를 통해 구체적으로 어떻게 작업하는지 알아보겠습니다. 실행을 클릭하면 즉시 결과를 얻을 수 있습니다. 다음과 같습니다:
{
  "task_id": "c9aaffa2-b8ac-40ff-8468-43e77cb9ddde"
}
내용은 다음과 같습니다:
{
    "success": true,
    "task_id": "c9aaffa2-b8ac-40ff-8468-43e77cb9ddde",
    "trace_id": "131a40c3-2eaf-44c9-af28-c9b408577286",
    "data": [
        {
            "prompt": "모델의 포즈와 액체 의상의 흐르는 형태를 변경하지 마십시오. 의류 재료를 은 금속에서 완전히 투명한 물(또는 유리)로 변경하십시오. 액체 흐름을 통해 모델 피부의 세부 사항이 보입니다. 빛과 그림자 효과는 반사에서 굴절로 전환됩니다.",
            "size": "2048x2048",
            "image_url": "https://platform.cdn.acedata.cloud/seedream/3e88db7e-4771-4f6a-adbd-5ae4590c5d59.jpg"
        }
    ]
}
결과에 task_id 필드가 있으며, 다른 필드는 위와 유사하여 이 필드를 통해 작업을 연결할 수 있습니다.

오류 처리

API를 호출할 때 오류가 발생하면 API는 해당 오류 코드와 정보를 반환합니다. 예를 들어:
  • 400 token_mismatched: 잘못된 요청, 누락되거나 잘못된 매개변수 때문일 수 있습니다.
  • 400 api_not_implemented: 잘못된 요청, 누락되거나 잘못된 매개변수 때문일 수 있습니다.
  • 401 invalid_token: 권한 없음, 잘못되었거나 누락된 인증 토큰입니다.
  • 429 too_many_requests: 요청이 너무 많음, 비율 제한을 초과했습니다.
  • 500 api_error: 내부 서버 오류, 서버에서 문제가 발생했습니다.

오류 응답 예시

{
  "success": false,
  "error": {
    "code": "api_error",
    "message": "fetch failed"
  },
  "trace_id": "2cf86e86-22a4-46e1-ac2f-032c0f2a4e89"
}

결론

이 문서를 통해 SeeDream Images Generation API를 사용하여 입력 프롬프트를 통해 이미지를 생성하는 방법을 이해하셨습니다. 이 문서가 API를 더 잘 연결하고 사용하는 데 도움이 되기를 바랍니다. 질문이 있으시면 언제든지 기술 지원 팀에 문의해 주십시오.