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.
Processes multiple images or pages in a single request, optimizing large-scale document workflows.
Detects underexposed or overexposed images to ensure optimal OCR and document processing visibility.
Flags excessive noise, distortions, or artifacts that may impact document clarity.
Ensures documents contain readable text, preventing submission of blank or noneligible pages
Annual API Volume
Accuracy Rate
Daily API Volume
Time to launch
Hassle-Free,
No Code Platform
Easy to adopt
& integrate
99.99%
API Success Rate
Reliable &
Secure
15 April 2023
The importance of identity verification for banks and businesses cannot be...
16 Apr 2024
In today's competitive financial landscape, customer onboarding...
14 March 2024
The current KYC procedures have been resource-intensive, prone...
Select Input Parameters
Check out the API results using samples provided below.
Please wait...
{{output.body.error_message}}
No Data Found
Key | Value |
---|---|
{{k|clean|capitalize:true}} | : {{v}} |
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)
Name | Description |
---|---|
token | String |
Name | Description |
---|---|
body |
{ "req_id" : < string >, "doc_base64": < base64 encoded string > "brightness" : < boolean >, "word_presence" : < boolean >, "blur" : < boolean >, "noise" : < boolean >, "blank_page" : < boolean >, } |
Name | Description |
---|---|
body |
{ "req_id" : < string >, "success" : < boolean >, "error_message" : < string >, "document_QC" : < dictonary >, } |
Fields | Values/Description |
---|---|
req_id | Unique request ID used for processing requests |
doc_base64 | Base64 encoded string of the document |
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 |