Convert Scanned PDF into Searchable PDF in JavaScript using PDF.co Web API
In this tutorial, we will demonstrate how to convert a scanned PDF into a searchable PDF in JavaScript using PDF.co Web API. The asynchronous processing approach ensures scalability, faster response times, and improved efficiency when handling large files or multiple tasks simultaneously.
Below is the image of the input file
data:image/s3,"s3://crabby-images/48834/4883488f594a19de0b1ae3e5c5a59916cb7aa611" alt="Input File"
Step 1: Prerequisites and Source Code
Begin by setting up your environment in Visual Studio Code and saving the following files:
Step 2: Install Axios Module
Install Axios, a modern HTTP client for making API requests. Run the following command in your terminal:
npm install axios
Step 3: Add PDF.co API Key
Replace the placeholder with your PDF.co API Key in the source code. You can obtain your API Key from the PDF.co Dashboard.
data:image/s3,"s3://crabby-images/2d683/2d683d2e90be62f0ea4e0a83beaf2a32c16c2f54" alt="Add PDF.co API Key"
Step 4: Specify Source PDF File
Provide the path to the scanned PDF file you want to convert.
data:image/s3,"s3://crabby-images/d8f6e/d8f6eaa45560046c9e06408d1b6e1ad301396e5d" alt="Specify Source PDF File"
Step 5: Set Destination File Name
Specify your desired output file name in the source code.
data:image/s3,"s3://crabby-images/90fd5/90fd57920370d2c1749a1ff3b206cb83366a8603" alt="Set Destination File Name"
Step 6: Execute the Program
- Save your JavaScript file as
index.js
. - Open a terminal, navigate to the project directory, and run:
node index.js
How It Works
Initiating an Asynchronous Conversion:
- The code sends a request to the PDF.co API to start converting the PDF files, with the async option set to
true
to enable asynchronous processing. - The API response contains a job ID and a URL to monitor the conversion status.
Checking Job Status:
- The code uses the job ID to periodically query the job's status by sending requests to the API.
- Once the status changes to "
success
", it indicates that the conversion process is complete, and the result file is ready for download.
Downloading the Result:
- After the conversion is successfully completed, the code retrieves the converted PDF files from the provided URLs and saves them with the name specified in the
destinationFile
variable to the specified location on the local system.
OUTPUT FILE
data:image/s3,"s3://crabby-images/18f1a/18f1a390638090548ee046343218db06dd6ef0b5" alt="OUTPUT FILE"
By following this tutorial, you’ve learned how to:
- Upload a scanned PDF file to PDF.co.
- Use asynchronous processing with Axios to convert it into a searchable PDF efficiently.
- Download and save the output file.
For more details on asynchronous processing, visit the PDF.co Asynchronous Processing Documentation.
Related Tutorials
data:image/s3,"s3://crabby-images/708ab/708ab1fff1041b667446e8bda0ee2399b271ea6d" alt="Tutorial default thumbnail"
data:image/s3,"s3://crabby-images/708ab/708ab1fff1041b667446e8bda0ee2399b271ea6d" alt="Tutorial default thumbnail"
data:image/s3,"s3://crabby-images/708ab/708ab1fff1041b667446e8bda0ee2399b271ea6d" alt="Tutorial default thumbnail"
data:image/s3,"s3://crabby-images/708ab/708ab1fff1041b667446e8bda0ee2399b271ea6d" alt="Tutorial default thumbnail"