> ## Documentation Index
> Fetch the complete documentation index at: https://docs.apimart.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Gemini-3.1-Flash-Lite-Image (Nano Banana Lite) 이미지 생성

>  - Gemini 3.1 시리즈에서 가장 빠르고 저렴한 이미지 모델, 대규모·저비용 이미지 생성에 특화
- 1K 해상도만 지원 (2K/4K/0.5K 전달 시 자동으로 1K로 다운그레이드되며 오류 없음)
- 텍스트-이미지, 이미지-이미지 지원, 최대 14장의 참조 이미지
- input / output 토큰 기준 과금; 공식 Gemini 채널 직접 연결, 비동기 작업으로 이미지 생성 

<RequestExample>
  ```bash cURL theme={null}
  curl --request POST \
    --url https://api.apimart.ai/v1/images/generations \
    --header 'Authorization: Bearer <token>' \
    --header 'Content-Type: application/json' \
    --data '{
      "model": "gemini-3.1-flash-lite-image",
      "prompt": "赛博朋克风格的城市夜景，霓虹灯闪烁",
      "size": "16:9",
      "resolution": "1K",
      "n": 1
    }'
  ```

  ```python Python theme={null}
  import requests

  url = "https://api.apimart.ai/v1/images/generations"

  payload = {
      "model": "gemini-3.1-flash-lite-image",
      "prompt": "赛博朋克风格的城市夜景，霓虹灯闪烁",
      "size": "16:9",
      "resolution": "1K",
      "n": 1
  }

  headers = {
      "Authorization": "Bearer <token>",
      "Content-Type": "application/json"
  }

  response = requests.post(url, json=payload, headers=headers)

  print(response.json())
  ```

  ```javascript JavaScript theme={null}
  const url = "https://api.apimart.ai/v1/images/generations";

  const payload = {
    model: "gemini-3.1-flash-lite-image",
    prompt: "赛博朋克风格的城市夜景，霓虹灯闪烁",
    size: "16:9",
    resolution: "1K",
    n: 1
  };

  const headers = {
    "Authorization": "Bearer <token>",
    "Content-Type": "application/json"
  };

  fetch(url, {
    method: "POST",
    headers: headers,
    body: JSON.stringify(payload)
  })
    .then(response => response.json())
    .then(data => console.log(data))
    .catch(error => console.error('Error:', error));
  ```

  ```go Go theme={null}
  package main

  import (
      "bytes"
      "encoding/json"
      "fmt"
      "io/ioutil"
      "net/http"
  )

  func main() {
      url := "https://api.apimart.ai/v1/images/generations"

      payload := map[string]interface{}{
          "model":      "gemini-3.1-flash-lite-image",
          "prompt":     "赛博朋克风格的城市夜景，霓虹灯闪烁",
          "size":       "16:9",
          "resolution": "1K",
          "n":          1,
      }

      jsonData, _ := json.Marshal(payload)

      req, _ := http.NewRequest("POST", url, bytes.NewBuffer(jsonData))
      req.Header.Set("Authorization", "Bearer <token>")
      req.Header.Set("Content-Type", "application/json")

      client := &http.Client{}
      resp, err := client.Do(req)
      if err != nil {
          panic(err)
      }
      defer resp.Body.Close()

      body, _ := ioutil.ReadAll(resp.Body)
      fmt.Println(string(body))
  }
  ```

  ```java Java theme={null}
  import java.net.http.HttpClient;
  import java.net.http.HttpRequest;
  import java.net.http.HttpResponse;
  import java.net.URI;

  public class Main {
      public static void main(String[] args) throws Exception {
          String url = "https://api.apimart.ai/v1/images/generations";

          String payload = """
          {
            "model": "gemini-3.1-flash-lite-image",
            "prompt": "赛博朋克风格的城市夜景，霓虹灯闪烁",
            "size": "16:9",
            "resolution": "1K",
            "n": 1
          }
          """;

          HttpClient client = HttpClient.newHttpClient();
          HttpRequest request = HttpRequest.newBuilder()
              .uri(URI.create(url))
              .header("Authorization", "Bearer <token>")
              .header("Content-Type", "application/json")
              .POST(HttpRequest.BodyPublishers.ofString(payload))
              .build();

          HttpResponse<String> response = client.send(request,
              HttpResponse.BodyHandlers.ofString());

          System.out.println(response.body());
      }
  }
  ```

  ```php PHP theme={null}
  <?php

  $url = "https://api.apimart.ai/v1/images/generations";

  $payload = [
      "model" => "gemini-3.1-flash-lite-image",
      "prompt" => "赛博朋克风格的城市夜景，霓虹灯闪烁",
      "size" => "16:9",
      "resolution" => "1K",
      "n" => 1
  ];

  $ch = curl_init($url);
  curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  curl_setopt($ch, CURLOPT_POST, true);
  curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($payload));
  curl_setopt($ch, CURLOPT_HTTPHEADER, [
      "Authorization: Bearer <token>",
      "Content-Type: application/json"
  ]);

  $response = curl_exec($ch);
  curl_close($ch);

  echo $response;
  ?>
  ```

  ```ruby Ruby theme={null}
  require 'net/http'
  require 'json'
  require 'uri'

  url = URI("https://api.apimart.ai/v1/images/generations")

  payload = {
    model: "gemini-3.1-flash-lite-image",
    prompt: "赛博朋克风格的城市夜景，霓虹灯闪烁",
    size: "16:9",
    resolution: "1K",
    n: 1
  }

  http = Net::HTTP.new(url.host, url.port)
  http.use_ssl = true

  request = Net::HTTP::Post.new(url)
  request["Authorization"] = "Bearer <token>"
  request["Content-Type"] = "application/json"
  request.body = payload.to_json

  response = http.request(request)
  puts response.body
  ```

  ```swift Swift theme={null}
  import Foundation

  let url = URL(string: "https://api.apimart.ai/v1/images/generations")!

  let payload: [String: Any] = [
      "model": "gemini-3.1-flash-lite-image",
      "prompt": "赛博朋克风格的城市夜景，霓虹灯闪烁",
      "size": "16:9",
      "resolution": "1K",
      "n": 1
  ]

  var request = URLRequest(url: url)
  request.httpMethod = "POST"
  request.setValue("Bearer <token>", forHTTPHeaderField: "Authorization")
  request.setValue("application/json", forHTTPHeaderField: "Content-Type")
  request.httpBody = try? JSONSerialization.data(withJSONObject: payload)

  let task = URLSession.shared.dataTask(with: request) { data, response, error in
      if let error = error {
          print("Error: \(error)")
          return
      }

      if let data = data, let responseString = String(data: data, encoding: .utf8) {
          print(responseString)
      }
  }

  task.resume()
  ```

  ```csharp C# theme={null}
  using System;
  using System.Net.Http;
  using System.Text;
  using System.Threading.Tasks;

  class Program
  {
      static async Task Main(string[] args)
      {
          var url = "https://api.apimart.ai/v1/images/generations";

          var payload = @"{
              ""model"": ""gemini-3.1-flash-lite-image"",
              ""prompt"": ""赛博朋克风格的城市夜景，霓虹灯闪烁"",
              ""size"": ""16:9"",
              ""resolution"": ""1K"",
              ""n"": 1
          }";

          using var client = new HttpClient();
          client.DefaultRequestHeaders.Add("Authorization", "Bearer <token>");

          var content = new StringContent(payload, Encoding.UTF8, "application/json");
          var response = await client.PostAsync(url, content);
          var result = await response.Content.ReadAsStringAsync();

          Console.WriteLine(result);
      }
  }
  ```

  ```c C theme={null}
  #include <stdio.h>
  #include <curl/curl.h>

  int main(void) {
      CURL *curl;
      CURLcode res;

      curl_global_init(CURL_GLOBAL_DEFAULT);
      curl = curl_easy_init();

      if(curl) {
          const char *url = "https://api.apimart.ai/v1/images/generations";
          const char *payload = "{"
              "\"model\":\"gemini-3.1-flash-lite-image\","
              "\"prompt\":\"赛博朋克风格的城市夜景，霓虹灯闪烁\","
              "\"size\":\"16:9\","
              "\"resolution\":\"1K\","
              "\"n\":1"
          "}";

          struct curl_slist *headers = NULL;
          headers = curl_slist_append(headers, "Authorization: Bearer <token>");
          headers = curl_slist_append(headers, "Content-Type: application/json");

          curl_easy_setopt(curl, CURLOPT_URL, url);
          curl_easy_setopt(curl, CURLOPT_POSTFIELDS, payload);
          curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);

          res = curl_easy_perform(curl);

          if(res != CURLE_OK) {
              fprintf(stderr, "curl_easy_perform() failed: %s\n",
                      curl_easy_strerror(res));
          }

          curl_slist_free_all(headers);
          curl_easy_cleanup(curl);
      }

      curl_global_cleanup();
      return 0;
  }
  ```

  ```objectivec Objective-C theme={null}
  #import <Foundation/Foundation.h>

  int main(int argc, const char * argv[]) {
      @autoreleasepool {
          NSURL *url = [NSURL URLWithString:@"https://api.apimart.ai/v1/images/generations"];

          NSDictionary *payload = @{
              @"model": @"gemini-3.1-flash-lite-image",
              @"prompt": @"赛博朋克风格的城市夜景，霓虹灯闪烁",
              @"size": @"16:9",
              @"resolution": @"1K",
              @"n": @1
          };

          NSError *error;
          NSData *jsonData = [NSJSONSerialization dataWithJSONObject:payload
                                                            options:0
                                                              error:&error];

          NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
          [request setHTTPMethod:@"POST"];
          [request setValue:@"Bearer <token>" forHTTPHeaderField:@"Authorization"];
          [request setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
          [request setHTTPBody:jsonData];

          NSURLSessionDataTask *task = [[NSURLSession sharedSession]
              dataTaskWithRequest:request
              completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
                  if (error) {
                      NSLog(@"Error: %@", error);
                      return;
                  }
                  NSString *result = [[NSString alloc] initWithData:data
                                                          encoding:NSUTF8StringEncoding];
                  NSLog(@"%@", result);
              }];

          [task resume];
          [[NSRunLoop mainRunLoop] run];
      }
      return 0;
  }
  ```

  ```ocaml OCaml theme={null}
  (* Requires cohttp and yojson libraries *)
  open Lwt
  open Cohttp
  open Cohttp_lwt_unix

  let url = "https://api.apimart.ai/v1/images/generations"

  let payload = {|{
    "model": "gemini-3.1-flash-lite-image",
    "prompt": "赛博朋克风格的城市夜景，霓虹灯闪烁",
    "size": "16:9",
    "resolution": "1K",
    "n": 1
  }|}

  let () =
    let headers = Header.init ()
      |> fun h -> Header.add h "Authorization" "Bearer <token>"
      |> fun h -> Header.add h "Content-Type" "application/json"
    in
    let body = Cohttp_lwt.Body.of_string payload in

    let response = Client.post ~headers ~body (Uri.of_string url) >>= fun (resp, body) ->
      body |> Cohttp_lwt.Body.to_string >|= fun body_str ->
      print_endline body_str
    in
    Lwt_main.run response
  ```

  ```dart Dart theme={null}
  import 'dart:convert';
  import 'package:http/http.dart' as http;

  void main() async {
    final url = Uri.parse('https://api.apimart.ai/v1/images/generations');

    final payload = {
      'model': 'gemini-3.1-flash-lite-image',
      'prompt': '赛博朋克风格的城市夜景，霓虹灯闪烁',
      'size': '16:9',
      'resolution': '1K',
      'n': 1
    };

    final response = await http.post(
      url,
      headers: {
        'Authorization': 'Bearer <token>',
        'Content-Type': 'application/json',
      },
      body: jsonEncode(payload),
    );

    print(response.body);
  }
  ```

  ```r R theme={null}
  library(httr)
  library(jsonlite)

  url <- "https://api.apimart.ai/v1/images/generations"

  payload <- list(
    model = "gemini-3.1-flash-lite-image",
    prompt = "赛博朋克风格的城市夜景，霓虹灯闪烁",
    size = "16:9",
    resolution = "1K",
    n = 1
  )

  response <- POST(
    url,
    add_headers(
      Authorization = "Bearer <token>",
      `Content-Type` = "application/json"
    ),
    body = toJSON(payload, auto_unbox = TRUE),
    encode = "raw"
  )

  cat(content(response, "text"))
  ```
</RequestExample>

<ResponseExample>
  ```json 200 theme={null}
  {
    "code": 200,
    "data": [
      {
        "status": "submitted",
        "task_id": "task_01K8SGYNNNVBQTXNR4MM964S7K"
      }
    ]
  }
  ```

  ```json 400 theme={null}
  {
    "error": {
      "code": 400,
      "message": "请求参数无效",
      "type": "invalid_request_error"
    }
  }
  ```

  ```json 401 theme={null}
  {
    "error": {
      "code": 401,
      "message": "身份验证失败，请检查您的API密钥",
      "type": "authentication_error"
    }
  }
  ```

  ```json 402 theme={null}
  {
    "error": {
      "code": 402,
      "message": "账户余额不足，请充值后再试",
      "type": "payment_required"
    }
  }
  ```

  ```json 403 theme={null}
  {
    "error": {
      "code": 403,
      "message": "访问被禁止，您没有权限访问此资源",
      "type": "permission_error"
    }
  }
  ```

  ```json 429 theme={null}
  {
    "error": {
      "code": 429,
      "message": "请求过于频繁，请稍后再试",
      "type": "rate_limit_error"
    }
  }
  ```

  ```json 500 theme={null}
  {
    "error": {
      "code": 500,
      "message": "服务器内部错误，请稍后重试",
      "type": "server_error"
    }
  }
  ```

  ```json 502 theme={null}
  {
    "error": {
      "code": 502,
      "message": "网关错误，服务器暂时不可用",
      "type": "bad_gateway"
    }
  }
  ```
</ResponseExample>

## 인증

<ParamField header="Authorization" type="string" required>
  모든 API 엔드포인트는 Bearer Token 인증이 필요합니다

  API 키 받기:

  [API 키 관리 페이지](https://apimart.ai/keys)를 방문하여 API 키를 받으세요

  요청 헤더에 추가:

  ```
  Authorization: Bearer YOUR_API_KEY
  ```
</ParamField>

## Body

<ParamField body="model" type="string" default="gemini-3.1-flash-lite-image" required>
  이미지 생성 모델 이름

  다음 모델 이름을 지원합니다:

  * `gemini-3.1-flash-lite-image` (Nano Banana Lite)
  * `gemini-3.1-flash-lite-image-ext`

  <Note>
    두 모델은 매개변수와 제약이 동일합니다 (1K만 지원, `google_search` / `official_fallback` 미지원, 최대 14장 참조 이미지). 둘 다 `-official` 변형이 없고 `official_fallback` 폴백 매개변수도 지원하지 않습니다. 과금은 각 채널의 백엔드 설정을 따릅니다.
  </Note>
</ParamField>

<ParamField body="prompt" type="string" required>
  이미지 생성을 위한 텍스트 설명
</ParamField>

<ParamField body="size" type="string">
  이미지 종횡비

  지원되는 비율:

  * `auto` - 종횡비 자동 선택
  * `1:1` - 정사각형, 아바타, 소셜 미디어
  * `3:2` / `2:3` - 표준 사진
  * `4:3` / `3:4` - 전통적인 디스플레이 비율
  * `16:9` / `9:16` - 와이드스크린/세로 비디오 커버
  * `5:4` / `4:5` - Instagram 이미지
  * `21:9` - 울트라와이드 배너

  <Warning>
    텍스트-이미지 생성에서 `size`가 `auto`이면 기본값은 `1:1` 또는 `16:9`입니다. 이미지-이미지 생성은 업스트림 반환 비율을 따릅니다. (비율 지정을 권장합니다)
  </Warning>
</ParamField>

<ParamField body="resolution" type="string" default="1K">
  출력 이미지 해상도

  지원되는 값:

  * `1K` - 약 1024px, 표준 해상도 (**Lite는 이 옵션만 지원**)

  <Warning>
    **Lite는 1K만 지원합니다**. `2K` / `4K` / `0.5K`를 전달하면 **조용히 1K로 다운그레이드**되며, 오류가 발생하지 않고 실제로 고해상도를 출력하지도 않습니다. 프런트엔드 UI에서 해상도 옵션을 노출할 필요가 없습니다.
  </Warning>
</ParamField>

<ParamField body="n" type="integer" default="1">
  생성할 이미지 수

  값 범위: 1 \~ 4, 기본값 `1`

  `n>1`이면 백엔드가 업스트림에 여러 번 동시 요청하며, **실제 성공한 이미지 수**를 기준으로 과금합니다. **프런트엔드에서 1을 고정으로 전달하는 것을 권장합니다** (이미지별 진행 상황 표시, 과금이 더 직관적).

  **⚠️ 참고:** 숫자만 입력해야 하며 (예: `1`), 따옴표를 추가하면 오류가 발생합니다
</ParamField>

<ParamField body="image_urls" type="array">
  이미지-이미지 생성을 위한 참조 이미지 URL 목록

  두 가지 형식을 지원합니다:

  **1. 완전한 이미지 URL 주소**

  * 공개적으로 접근 가능한 이미지 URL (http\:// 또는 https\://)
  * 예: `https://example.com/image.jpg`

  **2. Base64 인코딩 형식**

  * **완전한 Data URI 형식을 사용해야 합니다**
  * 형식: `data:image/{형식};base64,{base64데이터}`
  * 지원되는 이미지 형식: jpeg, png, webp
  * 예: `data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABg...`
  * ⚠️ 참고: `data:image/jpeg;base64,` 접두사를 포함해야 합니다

  **제한:**

  * 최대 **14장** 참조 이미지 (권장: 최대 10장 객체 참조 + 4장 캐릭터 참조)
  * 이미지당 10MB 이하
  * 지원 형식: jpeg, png, webp
</ParamField>

<ParamField body="webhook" type="string">
  작업 콜백 주소 (base)

  작업 성공 / 실패 시 본 플랫폼이 `webhook + /callback`으로 콜백합니다 (업스트림은 전달하지 않음). 이 매개변수를 전달하면 폴링을 크게 줄일 수 있습니다; 그래도 폴백으로 폴링을 유지하는 것을 권장합니다.
</ParamField>

<Note>
  **Lite 사용 요점**

  * **`google_search` / `google_image_search` 미지원**: Lite는 Developer API의 `interactions` 엔드포인트를 사용하며, 업스트림에서 Search 도구를 개방하지 않았습니다 ("Search as tool is not enabled for this model"을 반환). 플랫폼 어댑터도 이 매개변수를 전달하지 않습니다. **전달해도 오류가 발생하지 않고 정상적으로 이미지를 생성하지만, 검색 강화 효과는 전혀 없습니다**. 검색 강화가 필요하면 `gemini-3.1-flash-image-preview`를 사용하세요.
  * `mask_url` 부분 리페인팅 미지원 (Gemini 시리즈는 aspect ratio + 참조 이미지를 사용하며, 마스크를 사용하지 않음).
  * **토큰 기준 과금** (flash/pro의 장당 고정 가격과 다름): 입력 약 $0.25/백만 토큰, 이미지 출력 약 $30/백만 토큰, 1K 장당 ≈ 1120 output 토큰 ≈ **\$0.0336/장**. 실제 가격은 백엔드 배율 설정을 따릅니다.
  * 생성된 모든 이미지에 Google **SynthID** 비가시성 워터마크가 포함됩니다 (업스트림 동작, 비활성화 불가).
</Note>

## 응답

<ResponseField name="code" type="integer">
  응답 상태 코드
</ResponseField>

<ResponseField name="data" type="array">
  응답 데이터 배열

  <Expandable title="속성">
    <ResponseField name="status" type="string">
      작업 상태

      * `submitted` - 제출됨
    </ResponseField>

    <ResponseField name="task_id" type="string">
      고유 작업 식별자
    </ResponseField>
  </Expandable>
</ResponseField>
