dall-e-2、gpt-image-1、最新的 gpt-image-2,以及通过同一接口接入的 nano-banana / nano-banana-2 / nano-banana-pro 系列模型。
本文档主要介绍 OpenAI Images Edits API 操作的使用流程,利用它我们可以轻松使用官方 OpenAI 图像编辑功能。
申请流程
要使用 OpenAI Images Edits API,首先到 Ace Data Cloud 控制台 获取您的 API Token,留作备用。
如果你尚未登录或注册,会自动跳转到登录页面邀请你注册和登录,完成后会自动返回当前页面。
一个 API Token 即可调用平台所有服务,无需为每个服务单独申请。 首次申请会赠送免费额度,可免费体验;额度不足时可在 控制台 充值通用余额。
📘 完整文档:OpenAI Images Edits API →
GPT-Image-2 模型
gpt-image-2 在图像编辑场景下相比 gpt-image-1 有非常明显的提升:
- 结构保持更稳定:换皮肤、换配色、换背景时几乎不会破坏原图的版式与构图。
- 文字保留更准确:信息图、海报、菜单等含文字的图片在编辑后文字仍然清晰可读。
- 支持 URL 直传:除了传统的
multipart/form-data文件上传,gpt-image-2还额外支持以 JSON 方式传入图片 URL,无需先把图片下载到本地,非常适合服务端流水线接入。 - 支持高分辨率重绘:可以传入一张 1K 原图,通过
size参数请求 2K / 4K 输出,模型会在编辑过程中同时完成放大。
支持的 size 取值
编辑接口对 size 的约束与生成接口完全一致——gpt-image-2 只需要 size 为 auto、空,或者符合 WIDTHxHEIGHT 格式,任何其他形态会返回 400。所有尺寸(1K / 2K / 4K / 自定义)按单张统一扣费,与原图分辨率和 size 请求值都无关。
上游对自定义尺寸的硬约束同样适用:宽高均为 16 的倍数、长边 ≤ 3840、总像素数 ≤ 8,294,400。
| 比例 | 1K 推荐 | 2K 推荐 | 4K 推荐 |
|---|---|---|---|
| 1:1 | 1024x1024 | 2048x2048 | 2880x2880 |
| 4:3 | 1536x1024 | 2048x1536 | 3264x2448 |
| 3:4 | 1024x1536 | 1536x2048 | 2448x3264 |
| 16:9 | 1792x1024 | 2048x1152 | 3840x2160 |
| 9:16 | 1024x1792 | 1152x2048 | 2160x3840 |
例如:原图是1024x1024,size传2048x2048时,模型会按编辑指令重绘并输出 2K 图;size传3840x2160时输出 4K 横屏图;传auto或省略则由模型自行选择。三者计费一致。
关于下面通过两个不同方位的真实示例感受n参数gpt-image-2编辑接口目前不支持n > 1:该参数会被静默忽略,无论传n=1还是n=10,单次请求都只会返回 1 张图,并且只按 1 张计费。如果你需要一次拿到多张候选编辑结果,请自行并发发起多次请求。该限制同样适用于gpt-image-1/gpt-image-1.5,以及nano-banana/nano-banana-2/nano-banana-pro系列。dall-e-2是目前唯一原生支持n > 1的编辑模型。
gpt-image-2 的编辑能力。
调用方式一:JSON + 图片 URL(推荐)
直接以application/json 方式发送请求,image 字段填入一张图片的 URL,模型会去抓取该图片并按 prompt 进行编辑。
例如,下面这张原图是用 gpt-image-2 生成的科普图鉴:


提示:image字段也支持传入一个数组,例如"image": ["url1", "url2", "url3"],最多可同时传入 16 张参考图,让模型综合参考多张图片进行编辑。
调用方式二:JSON + 多张参考图
gpt-image-2 支持同时参考多张图片来生成最终结果,例如把多张产品照合成到一张礼物篮中:
场景示例:换风格 + 保持结构
下面是另一个例子,把一张木质书架替换为现代浮架,但严格保留每层书本的数量和排列。 原图(用gpt-image-2 生成的木质书架):

task_id: e9544dba-727e-44a2-81e1-223d49869380):

调用方式三:multipart/form-data(兼容 OpenAI SDK)
如果你已经在使用官方 OpenAI Python SDK,原有的multipart/form-data 上传方式同样适用,只需把 model 改为 gpt-image-2:
OPENAI_BASE_URL 设为 https://api.acedata.cloud/openai,OPENAI_API_KEY 设为申请到的 token:
Nano Banana 系列模型
nano-banana 系列在编辑场景下同样接入了 /openai/images/edits,把 model 改为下表中的任意一个即可。
| 模型 | 计费(Credits / 次) | 适用场景 |
|---|---|---|
nano-banana | 0.14 | 普通图像编辑,速度最快、成本最低 |
nano-banana-2 | 0.28 | 质量与细节明显提升 |
nano-banana-pro | 0.35 | 系列中的旗舰,结构、文字、风格保留最佳 |
重要:参数支持范围 Nano Banana 通过适配层接入 OpenAI 协议,仅支持以下参数:model、prompt、image。
image既可以通过multipart/form-data上传文件(worker 内部会转成data:<mime>;base64,...传给上游),也可以通过表单字段直接传图片 URL 字符串。- 不支持
mask、n、size、response_format等参数;填了也会被忽略。- 返回结构遵循 OpenAI 格式(
data[].url),但created固定为0,且不会返回b64_json,revised_prompt始终等于原始prompt。
通过表单 + 图片 URL 调用

通过表单 + 本地文件调用
异步回调
callback_url 异步回调机制对 nano-banana 同样有效,调用流程与其它模型完全一致,详见下文 异步回调 一节。
基本使用
接下来就可以使用代码进行调用,下方是通过CURL进行调用:authorization,直接在下拉列表里面选择即可。另一个参数是 model, model 就是我们选择使用 OpenAI 官网模型类别,这里我们主要有 1 种模型,详情可以看我们提供的模型。还有一个参数是prompt,prompt 是我们输入要生成图像的提示词。最后一个参数是image,这个参数需要编辑的图片路径,需要编辑的图片如下图所示:

OPENAI_BASE_URL,可以设置为https://api.acedata.cloud/openai,还有一个使用凭证变量OPENAI_API_KEY,这个值是从authorization获取到的,在Mac OS可以通过以下命令设置环境变量:
gift-basket.png,具体的结果如下:

dall-e-2、gpt-image-1 和 gpt-image-2,其中 gpt-image-2 是当前推荐使用的模型,详见上文 GPT-Image-2 模型 一节。
异步回调
由于 OpenAI Images Edits API 编辑图片的时间可能相对较长,如果 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/3d32690d-6780-4187-a65c-870061e8c8ab。
接下来,我们可以设置字段 callback_url 为上述 Webhook URL,同时填入相应的参数,如以下代码所示:
task_id 字段,data 字段包含了和同步调用一样的图片编辑结果,通过 task_id 字段即可实现任务的关联。
错误处理
在调用 API 时,如果遇到错误,API 会返回相应的错误代码和信息。例如:400 token_mismatched:Bad request, possibly due to missing or invalid parameters.400 api_not_implemented:Bad request, possibly due to missing or invalid parameters.401 invalid_token:Unauthorized, invalid or missing authorization token.429 too_many_requests:Too many requests, you have exceeded the rate limit.500 api_error:Internal server error, something went wrong on the server.

