POST Remove the background of an image
{{baseUrl}}/removebg
BODY json

{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}
Examples
REQUEST

CURL *hnd = curl_easy_init();

curl_easy_setopt(hnd, CURLOPT_CUSTOMREQUEST, "POST");
curl_easy_setopt(hnd, CURLOPT_URL, "{{baseUrl}}/removebg");

struct curl_slist *headers = NULL;
headers = curl_slist_append(headers, "content-type: application/json");
curl_easy_setopt(hnd, CURLOPT_HTTPHEADER, headers);

curl_easy_setopt(hnd, CURLOPT_POSTFIELDS, "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}");

CURLcode ret = curl_easy_perform(hnd);
(require '[clj-http.client :as client])

(client/post "{{baseUrl}}/removebg" {:content-type :json
                                                     :form-params {:add_shadow false
                                                                   :bg_color ""
                                                                   :bg_image_url ""
                                                                   :channels ""
                                                                   :crop false
                                                                   :crop_margin ""
                                                                   :format ""
                                                                   :image_file_b64 ""
                                                                   :image_url ""
                                                                   :position ""
                                                                   :roi ""
                                                                   :scale ""
                                                                   :semitransparency false
                                                                   :size ""
                                                                   :type ""
                                                                   :type_level ""}})
require "http/client"

url = "{{baseUrl}}/removebg"
headers = HTTP::Headers{
  "content-type" => "application/json"
}
reqBody = "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}"

response = HTTP::Client.post url, headers: headers, body: reqBody
puts response.body
using System.Net.Http.Headers;
var client = new HttpClient();
var request = new HttpRequestMessage
{
    Method = HttpMethod.Post,
    RequestUri = new Uri("{{baseUrl}}/removebg"),
    Content = new StringContent("{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}")
    {
        Headers =
        {
            ContentType = new MediaTypeHeaderValue("application/json")
        }
    }
};
using (var response = await client.SendAsync(request))
{
    response.EnsureSuccessStatusCode();
    var body = await response.Content.ReadAsStringAsync();
    Console.WriteLine(body);
}
var client = new RestClient("{{baseUrl}}/removebg");
var request = new RestRequest("", Method.Post);
request.AddHeader("content-type", "application/json");
request.AddParameter("application/json", "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}", ParameterType.RequestBody);
var response = client.Execute(request);
package main

import (
	"fmt"
	"strings"
	"net/http"
	"io"
)

func main() {

	url := "{{baseUrl}}/removebg"

	payload := strings.NewReader("{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}")

	req, _ := http.NewRequest("POST", url, payload)

	req.Header.Add("content-type", "application/json")

	res, _ := http.DefaultClient.Do(req)

	defer res.Body.Close()
	body, _ := io.ReadAll(res.Body)

	fmt.Println(res)
	fmt.Println(string(body))

}
POST /baseUrl/removebg HTTP/1.1
Content-Type: application/json
Host: example.com
Content-Length: 303

{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}
AsyncHttpClient client = new DefaultAsyncHttpClient();
client.prepare("POST", "{{baseUrl}}/removebg")
  .setHeader("content-type", "application/json")
  .setBody("{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}")
  .execute()
  .toCompletableFuture()
  .thenAccept(System.out::println)
  .join();

client.close();
HttpRequest request = HttpRequest.newBuilder()
    .uri(URI.create("{{baseUrl}}/removebg"))
    .header("content-type", "application/json")
    .method("POST", HttpRequest.BodyPublishers.ofString("{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}"))
    .build();
HttpResponse response = HttpClient.newHttpClient().send(request, HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
OkHttpClient client = new OkHttpClient();

MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}");
Request request = new Request.Builder()
  .url("{{baseUrl}}/removebg")
  .post(body)
  .addHeader("content-type", "application/json")
  .build();

Response response = client.newCall(request).execute();
HttpResponse response = Unirest.post("{{baseUrl}}/removebg")
  .header("content-type", "application/json")
  .body("{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}")
  .asString();
const data = JSON.stringify({
  add_shadow: false,
  bg_color: '',
  bg_image_url: '',
  channels: '',
  crop: false,
  crop_margin: '',
  format: '',
  image_file_b64: '',
  image_url: '',
  position: '',
  roi: '',
  scale: '',
  semitransparency: false,
  size: '',
  type: '',
  type_level: ''
});

const xhr = new XMLHttpRequest();
xhr.withCredentials = true;

xhr.addEventListener('readystatechange', function () {
  if (this.readyState === this.DONE) {
    console.log(this.responseText);
  }
});

xhr.open('POST', '{{baseUrl}}/removebg');
xhr.setRequestHeader('content-type', 'application/json');

xhr.send(data);
import axios from 'axios';

const options = {
  method: 'POST',
  url: '{{baseUrl}}/removebg',
  headers: {'content-type': 'application/json'},
  data: {
    add_shadow: false,
    bg_color: '',
    bg_image_url: '',
    channels: '',
    crop: false,
    crop_margin: '',
    format: '',
    image_file_b64: '',
    image_url: '',
    position: '',
    roi: '',
    scale: '',
    semitransparency: false,
    size: '',
    type: '',
    type_level: ''
  }
};

try {
  const { data } = await axios.request(options);
  console.log(data);
} catch (error) {
  console.error(error);
}
const url = '{{baseUrl}}/removebg';
const options = {
  method: 'POST',
  headers: {'content-type': 'application/json'},
  body: '{"add_shadow":false,"bg_color":"","bg_image_url":"","channels":"","crop":false,"crop_margin":"","format":"","image_file_b64":"","image_url":"","position":"","roi":"","scale":"","semitransparency":false,"size":"","type":"","type_level":""}'
};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
const settings = {
  async: true,
  crossDomain: true,
  url: '{{baseUrl}}/removebg',
  method: 'POST',
  headers: {
    'content-type': 'application/json'
  },
  processData: false,
  data: '{\n  "add_shadow": false,\n  "bg_color": "",\n  "bg_image_url": "",\n  "channels": "",\n  "crop": false,\n  "crop_margin": "",\n  "format": "",\n  "image_file_b64": "",\n  "image_url": "",\n  "position": "",\n  "roi": "",\n  "scale": "",\n  "semitransparency": false,\n  "size": "",\n  "type": "",\n  "type_level": ""\n}'
};

$.ajax(settings).done(function (response) {
  console.log(response);
});
val client = OkHttpClient()

val mediaType = MediaType.parse("application/json")
val body = RequestBody.create(mediaType, "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}")
val request = Request.Builder()
  .url("{{baseUrl}}/removebg")
  .post(body)
  .addHeader("content-type", "application/json")
  .build()

val response = client.newCall(request).execute()
const http = require('https');

const options = {
  method: 'POST',
  hostname: 'example.com',
  port: null,
  path: '/baseUrl/removebg',
  headers: {
    'content-type': 'application/json'
  }
};

const req = http.request(options, function (res) {
  const chunks = [];

  res.on('data', function (chunk) {
    chunks.push(chunk);
  });

  res.on('end', function () {
    const body = Buffer.concat(chunks);
    console.log(body.toString());
  });
});

req.write(JSON.stringify({
  add_shadow: false,
  bg_color: '',
  bg_image_url: '',
  channels: '',
  crop: false,
  crop_margin: '',
  format: '',
  image_file_b64: '',
  image_url: '',
  position: '',
  roi: '',
  scale: '',
  semitransparency: false,
  size: '',
  type: '',
  type_level: ''
}));
req.end();
const request = require('request');

const options = {
  method: 'POST',
  url: '{{baseUrl}}/removebg',
  headers: {'content-type': 'application/json'},
  body: {
    add_shadow: false,
    bg_color: '',
    bg_image_url: '',
    channels: '',
    crop: false,
    crop_margin: '',
    format: '',
    image_file_b64: '',
    image_url: '',
    position: '',
    roi: '',
    scale: '',
    semitransparency: false,
    size: '',
    type: '',
    type_level: ''
  },
  json: true
};

request(options, function (error, response, body) {
  if (error) throw new Error(error);

  console.log(body);
});
const unirest = require('unirest');

const req = unirest('POST', '{{baseUrl}}/removebg');

req.headers({
  'content-type': 'application/json'
});

req.type('json');
req.send({
  add_shadow: false,
  bg_color: '',
  bg_image_url: '',
  channels: '',
  crop: false,
  crop_margin: '',
  format: '',
  image_file_b64: '',
  image_url: '',
  position: '',
  roi: '',
  scale: '',
  semitransparency: false,
  size: '',
  type: '',
  type_level: ''
});

req.end(function (res) {
  if (res.error) throw new Error(res.error);

  console.log(res.body);
});
const axios = require('axios').default;

const options = {
  method: 'POST',
  url: '{{baseUrl}}/removebg',
  headers: {'content-type': 'application/json'},
  data: {
    add_shadow: false,
    bg_color: '',
    bg_image_url: '',
    channels: '',
    crop: false,
    crop_margin: '',
    format: '',
    image_file_b64: '',
    image_url: '',
    position: '',
    roi: '',
    scale: '',
    semitransparency: false,
    size: '',
    type: '',
    type_level: ''
  }
};

try {
  const { data } = await axios.request(options);
  console.log(data);
} catch (error) {
  console.error(error);
}
const fetch = require('node-fetch');

const url = '{{baseUrl}}/removebg';
const options = {
  method: 'POST',
  headers: {'content-type': 'application/json'},
  body: '{"add_shadow":false,"bg_color":"","bg_image_url":"","channels":"","crop":false,"crop_margin":"","format":"","image_file_b64":"","image_url":"","position":"","roi":"","scale":"","semitransparency":false,"size":"","type":"","type_level":""}'
};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
#import 

NSDictionary *headers = @{ @"content-type": @"application/json" };
NSDictionary *parameters = @{ @"add_shadow": @NO,
                              @"bg_color": @"",
                              @"bg_image_url": @"",
                              @"channels": @"",
                              @"crop": @NO,
                              @"crop_margin": @"",
                              @"format": @"",
                              @"image_file_b64": @"",
                              @"image_url": @"",
                              @"position": @"",
                              @"roi": @"",
                              @"scale": @"",
                              @"semitransparency": @NO,
                              @"size": @"",
                              @"type": @"",
                              @"type_level": @"" };

NSData *postData = [NSJSONSerialization dataWithJSONObject:parameters options:0 error:nil];

NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:@"{{baseUrl}}/removebg"]
                                                       cachePolicy:NSURLRequestUseProtocolCachePolicy
                                                   timeoutInterval:10.0];
[request setHTTPMethod:@"POST"];
[request setAllHTTPHeaderFields:headers];
[request setHTTPBody:postData];

NSURLSession *session = [NSURLSession sharedSession];
NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request
                                            completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
                                                if (error) {
                                                    NSLog(@"%@", error);
                                                } else {
                                                    NSHTTPURLResponse *httpResponse = (NSHTTPURLResponse *) response;
                                                    NSLog(@"%@", httpResponse);
                                                }
                                            }];
[dataTask resume];
open Cohttp_lwt_unix
open Cohttp
open Lwt

let uri = Uri.of_string "{{baseUrl}}/removebg" in
let headers = Header.add (Header.init ()) "content-type" "application/json" in
let body = Cohttp_lwt_body.of_string "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}" in

Client.call ~headers ~body `POST uri
>>= fun (res, body_stream) ->
  (* Do stuff with the result *)
 "{{baseUrl}}/removebg",
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => "",
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 30,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => "POST",
  CURLOPT_POSTFIELDS => json_encode([
    'add_shadow' => null,
    'bg_color' => '',
    'bg_image_url' => '',
    'channels' => '',
    'crop' => null,
    'crop_margin' => '',
    'format' => '',
    'image_file_b64' => '',
    'image_url' => '',
    'position' => '',
    'roi' => '',
    'scale' => '',
    'semitransparency' => null,
    'size' => '',
    'type' => '',
    'type_level' => ''
  ]),
  CURLOPT_HTTPHEADER => [
    "content-type: application/json"
  ],
]);

$response = curl_exec($curl);
$err = curl_error($curl);

curl_close($curl);

if ($err) {
  echo "cURL Error #:" . $err;
} else {
  echo $response;
}
request('POST', '{{baseUrl}}/removebg', [
  'body' => '{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}',
  'headers' => [
    'content-type' => 'application/json',
  ],
]);

echo $response->getBody();
setUrl('{{baseUrl}}/removebg');
$request->setMethod(HTTP_METH_POST);

$request->setHeaders([
  'content-type' => 'application/json'
]);

$request->setContentType('application/json');
$request->setBody(json_encode([
  'add_shadow' => null,
  'bg_color' => '',
  'bg_image_url' => '',
  'channels' => '',
  'crop' => null,
  'crop_margin' => '',
  'format' => '',
  'image_file_b64' => '',
  'image_url' => '',
  'position' => '',
  'roi' => '',
  'scale' => '',
  'semitransparency' => null,
  'size' => '',
  'type' => '',
  'type_level' => ''
]));

try {
  $response = $request->send();

  echo $response->getBody();
} catch (HttpException $ex) {
  echo $ex;
}
append(json_encode([
  'add_shadow' => null,
  'bg_color' => '',
  'bg_image_url' => '',
  'channels' => '',
  'crop' => null,
  'crop_margin' => '',
  'format' => '',
  'image_file_b64' => '',
  'image_url' => '',
  'position' => '',
  'roi' => '',
  'scale' => '',
  'semitransparency' => null,
  'size' => '',
  'type' => '',
  'type_level' => ''
]));
$request->setRequestUrl('{{baseUrl}}/removebg');
$request->setRequestMethod('POST');
$request->setBody($body);

$request->setHeaders([
  'content-type' => 'application/json'
]);

$client->enqueue($request)->send();
$response = $client->getResponse();

echo $response->getBody();
$headers=@{}
$headers.Add("content-type", "application/json")
$response = Invoke-WebRequest -Uri '{{baseUrl}}/removebg' -Method POST -Headers $headers -ContentType 'application/json' -Body '{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}'
$headers=@{}
$headers.Add("content-type", "application/json")
$response = Invoke-RestMethod -Uri '{{baseUrl}}/removebg' -Method POST -Headers $headers -ContentType 'application/json' -Body '{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}'
import http.client

conn = http.client.HTTPSConnection("example.com")

payload = "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}"

headers = { 'content-type': "application/json" }

conn.request("POST", "/baseUrl/removebg", payload, headers)

res = conn.getresponse()
data = res.read()

print(data.decode("utf-8"))
import requests

url = "{{baseUrl}}/removebg"

payload = {
    "add_shadow": False,
    "bg_color": "",
    "bg_image_url": "",
    "channels": "",
    "crop": False,
    "crop_margin": "",
    "format": "",
    "image_file_b64": "",
    "image_url": "",
    "position": "",
    "roi": "",
    "scale": "",
    "semitransparency": False,
    "size": "",
    "type": "",
    "type_level": ""
}
headers = {"content-type": "application/json"}

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

print(response.json())
library(httr)

url <- "{{baseUrl}}/removebg"

payload <- "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}"

encode <- "json"

response <- VERB("POST", url, body = payload, content_type("application/json"), encode = encode)

content(response, "text")
require 'uri'
require 'net/http'

url = URI("{{baseUrl}}/removebg")

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

request = Net::HTTP::Post.new(url)
request["content-type"] = 'application/json'
request.body = "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}"

response = http.request(request)
puts response.read_body
require 'faraday'

conn = Faraday.new(
  url: 'https://example.com',
  headers: {'Content-Type' => 'application/json'}
)

response = conn.post('/baseUrl/removebg') do |req|
  req.body = "{\n  \"add_shadow\": false,\n  \"bg_color\": \"\",\n  \"bg_image_url\": \"\",\n  \"channels\": \"\",\n  \"crop\": false,\n  \"crop_margin\": \"\",\n  \"format\": \"\",\n  \"image_file_b64\": \"\",\n  \"image_url\": \"\",\n  \"position\": \"\",\n  \"roi\": \"\",\n  \"scale\": \"\",\n  \"semitransparency\": false,\n  \"size\": \"\",\n  \"type\": \"\",\n  \"type_level\": \"\"\n}"
end

puts response.status
puts response.body
use serde_json::json;
use reqwest;

#[tokio::main]
pub async fn main() {
    let url = "{{baseUrl}}/removebg";

    let payload = json!({
        "add_shadow": false,
        "bg_color": "",
        "bg_image_url": "",
        "channels": "",
        "crop": false,
        "crop_margin": "",
        "format": "",
        "image_file_b64": "",
        "image_url": "",
        "position": "",
        "roi": "",
        "scale": "",
        "semitransparency": false,
        "size": "",
        "type": "",
        "type_level": ""
    });

    let mut headers = reqwest::header::HeaderMap::new();
    headers.insert("content-type", "application/json".parse().unwrap());

    let client = reqwest::Client::new();
    let response = client.post(url)
        .headers(headers)
        .json(&payload)
        .send()
        .await;

    let results = response.unwrap()
        .json::()
        .await
        .unwrap();

    dbg!(results);
}
curl --request POST \
  --url {{baseUrl}}/removebg \
  --header 'content-type: application/json' \
  --data '{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}'
echo '{
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
}' |  \
  http POST {{baseUrl}}/removebg \
  content-type:application/json
wget --quiet \
  --method POST \
  --header 'content-type: application/json' \
  --body-data '{\n  "add_shadow": false,\n  "bg_color": "",\n  "bg_image_url": "",\n  "channels": "",\n  "crop": false,\n  "crop_margin": "",\n  "format": "",\n  "image_file_b64": "",\n  "image_url": "",\n  "position": "",\n  "roi": "",\n  "scale": "",\n  "semitransparency": false,\n  "size": "",\n  "type": "",\n  "type_level": ""\n}' \
  --output-document \
  - {{baseUrl}}/removebg
import Foundation

let headers = ["content-type": "application/json"]
let parameters = [
  "add_shadow": false,
  "bg_color": "",
  "bg_image_url": "",
  "channels": "",
  "crop": false,
  "crop_margin": "",
  "format": "",
  "image_file_b64": "",
  "image_url": "",
  "position": "",
  "roi": "",
  "scale": "",
  "semitransparency": false,
  "size": "",
  "type": "",
  "type_level": ""
] as [String : Any]

let postData = JSONSerialization.data(withJSONObject: parameters, options: [])

let request = NSMutableURLRequest(url: NSURL(string: "{{baseUrl}}/removebg")! as URL,
                                        cachePolicy: .useProtocolCachePolicy,
                                    timeoutInterval: 10.0)
request.httpMethod = "POST"
request.allHTTPHeaderFields = headers
request.httpBody = postData as Data

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error as Any)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()
RESPONSE HEADERS

Content-Type
application/json
RESPONSE BODY json

{
  "data": {
    "foreground_height": 100,
    "foreground_left": 0,
    "foreground_top": 0,
    "foreground_width": 100,
    "result_b64": "iVBORw0KGgoAAAANSUhEUgAAAIsAAACFC..."
  }
}
RESPONSE HEADERS

Content-Type
image/*
RESPONSE BODY text

(binary image data)
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "failed_bg_download",
      "title": "Failed to download background image from given image_url: https://unsplash.com/"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "failed_image_download",
      "title": "Failed to download image from given image_url: https://unsplash.com/"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "failed_to_read_image",
      "title": "There was an error reading the image."
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "file_too_large",
      "detail": "File exceeds limit of 12MB",
      "title": "File too large"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_bg_color",
      "title": "Invalid bg_color parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_bg_image_url",
      "title": "Invalid bg_image_url: Please provide a valid URL."
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_channels",
      "title": "Invalid value for parameter 'channels'"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_crop_margin",
      "title": "Invalid crop_margin parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_dimensions",
      "detail": "The dimensions of the given image could not be read.",
      "title": "Failed to read image dimensions"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_file_type",
      "detail": "Expected jpg/png, received mp4",
      "title": "Invalid file type"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_format",
      "title": "Invalid format parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_image_url",
      "title": "Invalid image_url: Please provide a valid URL."
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_position",
      "title": "Invalid position parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_roi",
      "title": "Invalid roi parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_scale",
      "title": "Invalid scale parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_semitransparency",
      "title": "Invalid semitransparency parameter given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "invalid_size",
      "title": "Invalid value for parameter 'size'"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "missing_source",
      "detail": "Please provide the source image in the image_url, image_file or image_file_b64 parameter.",
      "title": "No image given"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "multiple_bg_sources",
      "title": "Multiple background sources given: Please provide either the bg_color, the bg_image_url or the bg_image_file parameter."
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "multiple_sources",
      "title": "Multiple image sources given: Please provide either the image_url, image_file or image_file_b64 parameter."
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "resolution_too_high",
      "detail": "Input image has 60 megapixels, maximum supported input resolution is 50 megapixels",
      "title": "Image resolution too high"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "roi_exceeds_bounds",
      "detail": "The given roi parameter defines a region that exceeds the image bounds",
      "title": "ROI exceeds image bounds"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "roi_region_empty",
      "detail": "The given roi parameter defines an empty region",
      "title": "ROI region is empty"
    }
  ]
}
RESPONSE HEADERS

Content-Type
*/*
RESPONSE BODY text

{
  "errors": [
    {
      "code": "unknown_foreground",
      "title": "Could not identify foreground in image. For details and recommendations see https://www.remove.bg/supported-images."
    }
  ]
}
GET Fetch credit balance and free API calls.
{{baseUrl}}/account
Examples
REQUEST

CURL *hnd = curl_easy_init();

curl_easy_setopt(hnd, CURLOPT_CUSTOMREQUEST, "GET");
curl_easy_setopt(hnd, CURLOPT_URL, "{{baseUrl}}/account");

CURLcode ret = curl_easy_perform(hnd);
(require '[clj-http.client :as client])

(client/get "{{baseUrl}}/account")
require "http/client"

url = "{{baseUrl}}/account"

response = HTTP::Client.get url
puts response.body
using System.Net.Http.Headers;
var client = new HttpClient();
var request = new HttpRequestMessage
{
    Method = HttpMethod.Get,
    RequestUri = new Uri("{{baseUrl}}/account"),
};
using (var response = await client.SendAsync(request))
{
    response.EnsureSuccessStatusCode();
    var body = await response.Content.ReadAsStringAsync();
    Console.WriteLine(body);
}
var client = new RestClient("{{baseUrl}}/account");
var request = new RestRequest("", Method.Get);
var response = client.Execute(request);
package main

import (
	"fmt"
	"net/http"
	"io"
)

func main() {

	url := "{{baseUrl}}/account"

	req, _ := http.NewRequest("GET", url, nil)

	res, _ := http.DefaultClient.Do(req)

	defer res.Body.Close()
	body, _ := io.ReadAll(res.Body)

	fmt.Println(res)
	fmt.Println(string(body))

}
GET /baseUrl/account HTTP/1.1
Host: example.com

AsyncHttpClient client = new DefaultAsyncHttpClient();
client.prepare("GET", "{{baseUrl}}/account")
  .execute()
  .toCompletableFuture()
  .thenAccept(System.out::println)
  .join();

client.close();
HttpRequest request = HttpRequest.newBuilder()
    .uri(URI.create("{{baseUrl}}/account"))
    .method("GET", HttpRequest.BodyPublishers.noBody())
    .build();
HttpResponse response = HttpClient.newHttpClient().send(request, HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
OkHttpClient client = new OkHttpClient();

Request request = new Request.Builder()
  .url("{{baseUrl}}/account")
  .get()
  .build();

Response response = client.newCall(request).execute();
HttpResponse response = Unirest.get("{{baseUrl}}/account")
  .asString();
const data = null;

const xhr = new XMLHttpRequest();
xhr.withCredentials = true;

xhr.addEventListener('readystatechange', function () {
  if (this.readyState === this.DONE) {
    console.log(this.responseText);
  }
});

xhr.open('GET', '{{baseUrl}}/account');

xhr.send(data);
import axios from 'axios';

const options = {method: 'GET', url: '{{baseUrl}}/account'};

try {
  const { data } = await axios.request(options);
  console.log(data);
} catch (error) {
  console.error(error);
}
const url = '{{baseUrl}}/account';
const options = {method: 'GET'};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
const settings = {
  async: true,
  crossDomain: true,
  url: '{{baseUrl}}/account',
  method: 'GET',
  headers: {}
};

$.ajax(settings).done(function (response) {
  console.log(response);
});
val client = OkHttpClient()

val request = Request.Builder()
  .url("{{baseUrl}}/account")
  .get()
  .build()

val response = client.newCall(request).execute()
const http = require('https');

const options = {
  method: 'GET',
  hostname: 'example.com',
  port: null,
  path: '/baseUrl/account',
  headers: {}
};

const req = http.request(options, function (res) {
  const chunks = [];

  res.on('data', function (chunk) {
    chunks.push(chunk);
  });

  res.on('end', function () {
    const body = Buffer.concat(chunks);
    console.log(body.toString());
  });
});

req.end();
const request = require('request');

const options = {method: 'GET', url: '{{baseUrl}}/account'};

request(options, function (error, response, body) {
  if (error) throw new Error(error);

  console.log(body);
});
const unirest = require('unirest');

const req = unirest('GET', '{{baseUrl}}/account');

req.end(function (res) {
  if (res.error) throw new Error(res.error);

  console.log(res.body);
});
const axios = require('axios').default;

const options = {method: 'GET', url: '{{baseUrl}}/account'};

try {
  const { data } = await axios.request(options);
  console.log(data);
} catch (error) {
  console.error(error);
}
const fetch = require('node-fetch');

const url = '{{baseUrl}}/account';
const options = {method: 'GET'};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
#import 

NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:@"{{baseUrl}}/account"]
                                                       cachePolicy:NSURLRequestUseProtocolCachePolicy
                                                   timeoutInterval:10.0];
[request setHTTPMethod:@"GET"];

NSURLSession *session = [NSURLSession sharedSession];
NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request
                                            completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
                                                if (error) {
                                                    NSLog(@"%@", error);
                                                } else {
                                                    NSHTTPURLResponse *httpResponse = (NSHTTPURLResponse *) response;
                                                    NSLog(@"%@", httpResponse);
                                                }
                                            }];
[dataTask resume];
open Cohttp_lwt_unix
open Cohttp
open Lwt

let uri = Uri.of_string "{{baseUrl}}/account" in

Client.call `GET uri
>>= fun (res, body_stream) ->
  (* Do stuff with the result *)
 "{{baseUrl}}/account",
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => "",
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 30,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => "GET",
]);

$response = curl_exec($curl);
$err = curl_error($curl);

curl_close($curl);

if ($err) {
  echo "cURL Error #:" . $err;
} else {
  echo $response;
}
request('GET', '{{baseUrl}}/account');

echo $response->getBody();
setUrl('{{baseUrl}}/account');
$request->setMethod(HTTP_METH_GET);

try {
  $response = $request->send();

  echo $response->getBody();
} catch (HttpException $ex) {
  echo $ex;
}
setRequestUrl('{{baseUrl}}/account');
$request->setRequestMethod('GET');
$client->enqueue($request)->send();
$response = $client->getResponse();

echo $response->getBody();
$response = Invoke-WebRequest -Uri '{{baseUrl}}/account' -Method GET 
$response = Invoke-RestMethod -Uri '{{baseUrl}}/account' -Method GET 
import http.client

conn = http.client.HTTPSConnection("example.com")

conn.request("GET", "/baseUrl/account")

res = conn.getresponse()
data = res.read()

print(data.decode("utf-8"))
import requests

url = "{{baseUrl}}/account"

response = requests.get(url)

print(response.json())
library(httr)

url <- "{{baseUrl}}/account"

response <- VERB("GET", url, content_type("application/octet-stream"))

content(response, "text")
require 'uri'
require 'net/http'

url = URI("{{baseUrl}}/account")

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

request = Net::HTTP::Get.new(url)

response = http.request(request)
puts response.read_body
require 'faraday'

conn = Faraday.new(
  url: 'https://example.com',
)

response = conn.get('/baseUrl/account') do |req|
end

puts response.status
puts response.body
use reqwest;

#[tokio::main]
pub async fn main() {
    let url = "{{baseUrl}}/account";

    let client = reqwest::Client::new();
    let response = client.get(url)
        .send()
        .await;

    let results = response.unwrap()
        .json::()
        .await
        .unwrap();

    dbg!(results);
}
curl --request GET \
  --url {{baseUrl}}/account
http GET {{baseUrl}}/account
wget --quiet \
  --method GET \
  --output-document \
  - {{baseUrl}}/account
import Foundation

let request = NSMutableURLRequest(url: NSURL(string: "{{baseUrl}}/account")! as URL,
                                        cachePolicy: .useProtocolCachePolicy,
                                    timeoutInterval: 10.0)
request.httpMethod = "GET"

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error as Any)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()