Image Quality Checker API

Ensure High-Quality, OCR-Ready Images with AI-Powered Analysis

The Image Quality Checker API ensures that images and PDFs meet the necessary quality standards for accurate Optical Character Recognition (OCR) processing. The API determines whether a document is OCR-ready or needs improvement by analyzing key factors such as brightness, blur, word presence, noise levels, and blank pages. Ideal for document verification, archiving, financial services, and automated workflows, this API ensures that only high-quality images and PDFs proceed to the next stage.

    Cutting-Edge Features    

Why Arya Image Quality Checker API?

High-Volume Batch Processing

Processes multiple images or pages in a single request, optimizing large-scale document workflows.

Intelligent Brightness Assessment

Detects underexposed or overexposed images to ensure optimal OCR and document processing visibility.

Noise & Distortion Filtering

Flags excessive noise, distortions, or artifacts that may impact document clarity.

Text Presence Verification

Ensures documents contain readable text, preventing submission of blank or noneligible pages

An AI Platform that you've
always wanted
With more than 80+ APIs, we stand out as the go-to-platform for developers, consistently delivering unparalleled success rates in driving critical decisions.
200 M+

Annual API Volume

95 %+

Accuracy Rate

720 K

Daily API Volume

< 5 Mins

Time to launch

    Effortless AI For Everyone    

More Reasons To Love Arya AI

Hassle-Free,

No Code Platform

Easy to adopt

& integrate

99.99%

API Success Rate

Reliable &

Secure

    Helpful Resources    

Learn More From Our Resources

Blog
Card image cap

15 April 2023

A Comprehensive Guide to AI Identity Verification

The importance of identity verification for banks and businesses cannot be...

Blog
Card image cap

16 Apr 2024

How KYC Automation Can Enhance Customer Onboarding Experience

In today's competitive financial landscape, customer onboarding...

Blog
Card image cap

14 March 2024

Automated KYC Verification with AI

The current KYC procedures have been resource-intensive, prone...

Select Input Parameters

Samples to try

Check out the API results using samples provided below.

Drag and drop files

Supports: PDF, JPG, PNG, etc

Drag and drop files

Supports: PDF, JPG, PNG, etc

Please wait...

Uploaded File

JSON
 
Copied

				
Key Value
{{k|clean|capitalize:true}} :  {{v}}

Documentation

HTTP Method: Post
Endpoint
{{getEndpoint(url, api_version, pageDetails.ping_endpoint)}}
Copied
API Token
{{tokenDisplay}}
Copied
API Token UAT
postman wrapper button
{{tokenUDisplay}}
Copied

Usage and Code Samples

curl --location --request POST '{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}' \
--header 'token: < your private token >' \
--header 'content-type: application/json' \
--data-raw '{
		"req_id": '< string >',
		"doc_base64": '< base64 string of document >',
		"brightness": '< boolean >'
		"blur": '< boolean >'
		"word_presence": '< boolean >'
		"noise": '< boolean >'
		"blank_page": '< boolean >'
	     }'
OkHttpClient client = new OkHttpClient().newBuilder().build();
MediaType mediaType = MediaType.parse("application/javascript");
RequestBody body = RequestBody.create(mediaType, "{  "doc_base64": '< base64 string of document >',"req_id": '< string >',"brightness": '< boolean >', "blur": '< boolean >',"word_presence": '< boolean >',"noise": '< boolean >',"blank_page": '< boolean >'  }");
Request request = new Request.Builder()
	.url("{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}")
	.method("POST", body)
	.addHeader("token", "< your private token >")
	.addHeader("content-type", "application/json")
	.build();
Response response = client.newCall(request).execute();
require "uri"
require "net/http"
url = URI("{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}")
https = Net::HTTP.new(url.host, url.port)
https.use_ssl = true
request = Net::HTTP::Post.new(url)
request["token"] = "< your private token >"
request["content-type"] = "application/json"
request.body = "{ "doc_base64": '< base64 string of document >',"req_id": < string >, "brightness": '< boolean >', "blur": '< boolean >',"word_presence": '< boolean >',"noise": '< boolean >',"blank_page": '< boolean >'  }"
response = https.request(request)
puts response.read_body
CURL *curl;
CURLcode res;
curl = curl_easy_init();
if(curl) {
  curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "POST");
  curl_easy_setopt(curl, CURLOPT_URL, "{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}");
  curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
  curl_easy_setopt(curl, CURLOPT_DEFAULT_PROTOCOL, "https");
  struct curl_slist *headers = NULL;
  headers = curl_slist_append(headers, "token: < your private token >");
  headers = curl_slist_append(headers, "content-type: application/json");
  curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
  const char *data = "{ "doc_base64": '< base64 string of document >',"req_id": < string >, "brightness": '< boolean >', "blur": '< boolean >',"word_presence": '< boolean >',"noise": '< boolean >',"blank_page": '< boolean >'  }";
  curl_easy_setopt(curl, CURLOPT_POSTFIELDS, data);
  res = curl_easy_perform(curl);
}
curl_easy_cleanup(curl);
var request = require('request');
var options = {
  'method': 'POST',
  'url': '{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}',
  'headers': {
  'token': '< your private token >',
  'content-type':'application/json'
},
body: '{ "doc_base64": "< base64 string of document >","req_id": < string >, "brightness": '< boolean >', "blur": '< boolean >',"word_presence": '< boolean >',"noise": '< boolean >',"blank_page": '< boolean >'  }'
};
request(options, function (error, response) {
if (error) throw new Error(error);
  console.log(response.body);
});
var client = new RestClient("{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}");
į¹£client.Timeout = -1;
var request = new RestRequest(Method.POST);
request.AddHeader("token", "< your private token >");
request.AddHeader("content-type", "application/json");
var body = @"{" + "" +
@"    "doc_base64": '< base64 string of document >'," + "" +
@"    "req_id": < string >" + "" +
@"    "brightness": < boolean >" + "" +
@"    "blur": < boolean >" + "" +
@"    "word_presence": < boolean >" + "" +
@"    "noise": < boolean >" + "" +
@"    "blank_page": < boolean >" + "" +
@"  }";
request.AddParameter("application/json", body,  ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
Console.WriteLine(response.Content);
php
require_once 'HTTP/Request2.php';
$request = new HTTP_Request2();
$request->setUrl('{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}');
$request->setMethod(HTTP_Request2::METHOD_POST);
$request->setConfig(array(
'follow_redirects' => TRUE
));
$request->setHeader(array(
  'token' => '< your private token >',
  'content-type' => 'application/json'
));
$request->setBody('{"doc_base64": "< base64 string of document >","req_id": < string >, "brightness": '< boolean >', "blur": '< boolean >',"word_presence": '< boolean >',"noise": '< boolean >',"blank_page": '< boolean >'  }');
try {
  $response = $request->send();
  if ($response->getStatus() == 200) {
  echo $response->getBody();
  }
  else {
  echo 'Unexpected HTTP status: ' . $response->getStatus() . ' ' .
  $response->getReasonPhrase();
  }
}
catch(HTTP_Request2_Exception $e) {
  echo 'Error: ' . $e->getMessage();
}
?>
import requests
url = "{{url}}/api/{{api_version}}/{{pageDetails.ping_endpoint}}"
payload = {"doc_base64": "< base64 string of document >", "req_id": < string >, "brightness": '< boolean >', "blur": '< boolean >',"word_presence": '< boolean >',"noise": '< boolean >',"blank_page": '< boolean >'  }
headers = {
  'token': '< your private token >',
  'content-type':'application/json'
}
response = requests.request("POST", url, json=payload, headers=headers)
print(response.text)

Request Parameters

Header parameters
Name Description
token String
Body parameters
Name Description
body {
  "req_id" : < string >,
  "doc_base64": < base64 encoded string >
  "brightness" : < boolean >,
  "word_presence" : < boolean >,
  "blur" : < boolean >,
  "noise" : < boolean >,
  "blank_page" : < boolean >,
}

Response Parameters

Status: 200 - API Request Successful
Body parameters
Name Description
body {
  "req_id" : < string >,
  "success" : < boolean >,
  "error_message" : < string >,
  "document_QC" : < dictonary >,
}

Field Details

Request Field Details
Fields Values/Description
req_id Unique request ID used for processing requests
doc_base64 Base64 encoded string of the document
Response Field Details
Fields Values/Description
req_id Corresponding request id
success Flag if the request is processed successfully
error_message If success is False then: Error message
document_QC Indicates whether the document should be accepted or rejected based on the page number