Link Search Menu Expand Document

PDF Fill PDF Forms

Explore Samples

PDF filler for fillable PDF forms using PDF.co.

To find form fields please use PDF.co PDF Edit Add Helper.

To get the list of all fillable fields inside PDF form, please use /pdf/info/fields endpoint.

If you need to create your own fillable form then please check PDF Create Fillable PDF Forms topic.

Available Methods

[POST] /pdf/edit/add (fill pdf form)

Add text, images, signatures, other pdfs, text fields, unchecked checkbox, checked checkbox to existing PDF file. You can fill out out existing PDF forms and documents and create new fillable PDF forms using this method.

Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.

To save an image or pdf for reuse as a template please use a link from Dropbox or Google Drive or from other storage. Or use built-in PDF.co Files storage. If you need to draw a signature and save it as an image then use this page.

Attributes
url required
URL to the source file. Supports links from Google Drive, Dropbox, and PDF.co built-in files storage. To upload files via API, Check out the Files Upload section.

Note: If you experience intermittent Too Many Requests or Access Denied errors, please try to add cache: to enable built-in URL caching. (e.g cache:https://example.com/file1.pdf)

For data security, you have the option to encrypt output files and decrypt input files. Learn more about user-controlled data encryption.
httpusername optional
HTTP auth user name if required to access source url.
httppassword optional
HTTP auth password if required to access source url.
annotations[] optional
The array of objects, Array of text objects to be added on top of pdf. Text objects can be ready-only ("type": "text" by default) or interactive as input fields ("type": "textField") or checkboxes ("type": "checkbox").
Attributes for annotations objects
text
String to add, If you need to insert a line break then use \n or {{$$newLine}}.
You can also use built-in macros like {{$$PageNumber}} and custom data macros. Check this knowledgebase article for more details on macros.
x
X coordinate Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
y
Y coordinate Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
width optional
Width of the text box Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
height optional
Height of the text box Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
alignment optional, default is left.
Sets text alignment within the width of the text box. Valid values: left, center, right.
pages optional
Comma-separated indices of pages (or page ranges) that you want to use.
The first-page index is always 0, For example, if you have a 7-page document that you want to be split into 3 separate PDFs but a different number of pages it would go like this: 0, 1, 2- or 1, 2, 3-7 which will result in 1 PDF with page one, 1 PDF with page two and one PDF with the rest of the pages.
You can also use inverted page numbers adding ‘!’ before the number. E.g. “!0” means “the last page”, “1-!1” means “from the second to the penultimate page”, and “!1-“ - last two pages”. Also, you can use a single asterisk (“*”) character as the range to split the document into separate pages. SPECIAL CASES: You can use a single asterisk * symbol to split the document into separate pages, The input must be in string format.
color optional, default is black.
Color for the text.
link optional
Sets link on click for text.
size optional, default is 12.
Set font size.
fontName optional, default is Arial.
Sets font name to use. Check the font list for all supported fonts.
fontBold optional, default is false.
Set to true to enable bold font style.
fontStrikeout optional, default is false.
Set to true to enable strikeout font style.
fontUnderline optional, default is false.
Set to true to enable underlined font style.
type optional, default is text.
Set object type, available types: text = text object, textfield = text input field, checkbox = checkbox field.
id optional
Sets id of the form field if type is not text.
Images
images[] array is optional
Array of image URLs (also can be a link to Files storage or datauri link) to be added on top of PDF file. Images can be loaded from URLs or from URLs for internal file storage.
Attributes for Images objects
url required
URL to image or pdf as HTTP link, file token or datauri:.. URL (with base64 encoded image or pdf).
x
X coordinate Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
y
Y coordinate Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
width optional
Width of the text box Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
height optional
Height of the text box Use PDF.co PDF Edit Add Helper to get or measure pdf coordinates.
pages optional
Comma-separated indices of pages (or page ranges) that you want to use.
The first-page Index is always 0. For example, if you have a 7 page document that you want to be split into 3 separate PDFs but a different number of pages it would go like this: 0, 1, 2- or 1, 2, 3-7 which will result in 1 PDF with page one, 1 PDF with page two and one PDF with the rest of the pages. You can also use inverted page numbers adding ‘!’ before the number. E.g. “!0” means “the last page”, “1-!1” means “from the second to the penultimate page”, and “!1-“ - last two pages”. Also, you can use a single asterisk (“*”) character as the range to split the document into separate pages. SPECIAL CASES: You can use a single asterisk * symbol to split the document into separate pages, The input must be in string format.
link optional
Link to open on click.
keepAspectRatio optional, true by default.
Set to false if don’t need to keep the aspect ratio for the image/pdf added. In this case, it will use the width and height parameters provided.
Fields
fields[] array is optional)
Array of values to update fillable pdf fields in input pdf. You can create your own automated PDF filler for your pdf forms using this array.
Attributes for Fields objects
fieldName
Name of the form field. To find form fields please use PDF.co PDF Edit Add Helper
pages optional
Page index where this form field appears.
text
Value to set for this field.
If you have a checkbox, set X, true, 1, or another text which is different from false to enable the checkbox. For radio buttons and combo boxes, you need to set the index of the item to select. To find form fields please use PDF.co PDF Edit Add Helper
fontName optional
Name of the font to use to fill out the input field. Check the font list for all supported fonts.
size optional
Override the font size of the text inside the given input field.
fontBold optional
Override font bold style of the text input field.
fontItalic optional
Override font italic style of the text input field.
fontStrikeout optional
Override font strikeout style of the text input field.
fontUnderline optional
Override font underline style of the text input field.

Tip: to turn all fillable fields into read-only fields, just set the profiles parameter (of the endpoint) to this value:
{ 'FlattenDocument()': [] }

Additional Attributes
password optional
Password of PDF file, The input must be in string format.
async optional
Set async to true for long processes to run in the background, API will then return a jobId which you can use with /job/check endpoint to check the status of the process and retrieve the output while you can proceed with other tasks without waiting for this process to finish.
IMPORTANT: Also set the inline param to true to get a direct link to the final output pdf in both sync and async modes. Otherwise, you will be getting a direct link to pdf in sync mode but also a link to the .json file in the async mode.
inline optional
Set to true to get a direct link to output pdf in async mode (otherwise you will get a link to JSON with URL inside when you use async mode).
name optional
File name for the generated output. Must be a String.
expiration optional
Set the expiration time for the output link in minutes (default is 60 i.e 60 minutes or 1 hour), After this specified duration, any generated output file(s) will be automatically deleted from PDF.co temporary files storage. The maximum duration for link expiration varies based on your current subscription plan. Learn more

To store permanent input files (e.g. re-usable images, pdf templates, documents), Consider using PDF.co built-in Files Storage.
profiles optional
You can set additional and extra options using this parameter that allows you to set custom configurations, The input must be in string format.

For example, to flatten pdf form set profiles to this value:

{ 'FlattenDocument()': [] }

See profiles samples for examples.

**Attributes **
templateData optional
Set JSON as an escaped string for use as custom macros. Seethis knowledgebase article for more details.
  • Method: POST
  • URL: /v1/pdf/edit/add

Query parameters

No query parameters accepted.

Body payload

{
    "async": false,
    "inline": true,
    "name": "f1040-filled",
    "url": "https://pdfco-test-files.s3.us-west-2.amazonaws.com/pdf-form/f1040.pdf",
    "fields": [
        {
            "fieldName": "topmostSubform[0].Page1[0].FilingStatus[0].c1_01[1]",
            "pages": "1", 
            "text": "True" 
        },
        {
            
            "fieldName": "topmostSubform[0].Page1[0].f1_02[0]",
            "pages": "1", 
            "text": "John A."
        },        
        {
            
            "fieldName": "topmostSubform[0].Page1[0].f1_03[0]",
            "pages": "1", 
            "text": "Doe"
        },        
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_04[0]",
            "pages": "1",
            "text": "123456789"
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_05[0]",
            "pages": "1",            
            "text": "Joan B.",
            "fontName": "Arial",
            "size": 6,
            "fontBold": true,
            "fontItalic": true,
            "fontStrikeout": true,
            "fontUnderline": true
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_05[0]",
            "pages": "1",
            "text": "Joan B."
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_06[0]",
            "pages": "1",
            "text": "Doe"
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_07[0]",
            "pages": "1",
            "text": "987654321"
        }     



    ],
    "annotations":[
        {
            "text":"Sample Filled with PDF.co API using /pdf/edit/add. Get fields from forms using /pdf/info/fields. This text is be added on the first (0) and the last (!0) pages.",
            "x": 400,
            "y": 10,
            "width": 200,
            "height": 500,
            "size": 12,            
            "pages": "0-",
            "color": "FF0000",
            "link": "https://pdf.co"
        }
    ],    
    "images": [
        {                             
            "pages": "!0", 
            "x": 100, 
            "y": 374,
            "width": 100, 
            "url": ""
        }
    ]
}

Example responses

/pdf/edit/add
{
    "hash": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
    "url": "https://pdf-temp-files.s3.amazonaws.com/cd15a09771554bed88d6419c1e2f2b16/f1040-filled.pdf",
    "pageCount": 3,
    "error": false,
    "status": 200,
    "name": "f1040-filled.pdf",
    "remainingCredits": 99999369,
    "credits": 63
}

Code Snippet

CURL
curl --location --request POST 'https://api.pdf.co/v1/pdf/edit/add' \
--header 'Content-Type: application/json' \
--header 'x-api-key: ' \
--data-raw '{
    "async": false,
    "inline": true,
    "name": "f1040-filled",
    "url": "https://pdfco-test-files.s3.us-west-2.amazonaws.com/pdf-form/f1040.pdf",
    "fields": [
        {
            "fieldName": "topmostSubform[0].Page1[0].FilingStatus[0].c1_01[1]",
            "pages": "1", 
            "text": "True" 
        },
        {
            
            "fieldName": "topmostSubform[0].Page1[0].f1_02[0]",
            "pages": "1", 
            "text": "John A."
        },        
        {
            
            "fieldName": "topmostSubform[0].Page1[0].f1_03[0]",
            "pages": "1", 
            "text": "Doe"
        },        
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_04[0]",
            "pages": "1",
            "text": "123456789"
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_05[0]",
            "pages": "1",            
            "text": "Joan B.",
            "fontName": "Arial",
            "size": 6,
            "fontBold": true,
            "fontItalic": true,
            "fontStrikeout": true,
            "fontUnderline": true
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_05[0]",
            "pages": "1",
            "text": "Joan B."
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_06[0]",
            "pages": "1",
            "text": "Doe"
        },
        {
            "fieldName": "topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_07[0]",
            "pages": "1",
            "text": "987654321"
        }     



    ],
    "annotations":[
        {
            "text":"Sample Filled with PDF.co API using /pdf/edit/add. Get fields from forms using /pdf/info/fields. This text is be added on the first (0) and the last (!0) pages.",
            "x": 400,
            "y": 10,
            "width": 200,
            "height": 500,
            "size": 12,            
            "pages": "0-",
            "color": "FF0000",
            "link": "https://pdf.co"
        }
    ],    
    "images": [
        {                             
            "pages": "!0", 
            "x": 100, 
            "y": 374,
            "width": 100, 
            "url": ""
        }
    ]
}'

[POST] /pdf/edit/add (fill pdf form with simplified params)

You can add fill pdf fields in existing PDF PDF forms. This method uses a simplified version of /pdf/edit/add.

Attributes
url required
URL to the source file. Supports links from Google Drive, Dropbox, and PDF.co built-in files storage. To upload files via API, Check out the Files Upload section.

Note: If you experience intermittent Too Many Requests or Access Denied errors, please try to add cache: to enable built-in URL caching. (e.g cache:https://example.com/file1.pdf)

For data security, you have the option to encrypt output files and decrypt input files. Learn more about user-controlled data encryption.
httpusername optional
HTTP auth user name if required to access source url.
httppassword optional
HTTP auth password if required to access source url.
fieldsString optional
Set values for fillable fields inside pdf forms. Use the following format page;fieldName;value.
Example: 0;editbox1;text is here. An advanced format can be used to override font name, size, and style:

0;fieldName;Field Text;12+bold+italic+underline+strikeout;FontName

Check the font list for all supported fonts.

Filling checkbox: for unchecked state please use false, no, not, none, unchecked or 0. To put a checkmark use X, true, or anything else.

Example: 0;checkbox1;true or 0;checkbox1;X
For multiple objects, use \| separator.
To find names of all fillable fields in a PDF file please use the /pdf/info/fields endpoint or interactive PDF.co Request Tester
annotationsString optional
Add one or more text objects on top of the PDF. Each text object to be added can be described as
x;y;pages;text;fontsize;fontname;fontcolor; link;transparent.

Sample: 20;20;0-;Testing Text;24;Arial;FF0000;www.pdf.co;false.

To separate multiple objects, use \| separator.
where 24 is the font size. You can also add styles to the font size using the following modifiers:
+bold optional
Bold style.
+italic optional
Italic style.
+underline optional
underline style
+strikeout optional
strikeout style.

Check the font list for all supported fonts.

For example, for font size 24 and bold, italic, underline and strikeout styles:

250;20;0-;PDF form filled with PDF.co API;24+bold+italic+underline+strikeout;Arial;FF0000;www.pdf.co;true

If you need to insert a line break then use \n or {{$$newLine}}.

You can also use built-in macros like {{$$PageNumber}} and custom data macros. Check this knowledgebase article for more details on macros.

 
imagesString optional
Adds one or more images or pdfs on top of the PDF. Each image or pdf object can be defined as
x;y;pages;urltoimageOrPdf;linkToOpen;width;height

For example:
20;80;0-;pdfco-test-files.s3.us-west-2.amazonaws.com/pdf-edit/logo.png;www.pdf.co;200;200.
To separate multiple objects, use \| separator.
password optional
Password of PDF file, The input must be in string format.
async optional
Set async to true for long processes to run in the background, API will then return a jobId which you can use with /job/check endpoint to check the status of the process and retrieve the output while you can proceed with other tasks without waiting for this process to finish.
Important: Also set the inline param to true to get a direct link to the final output pdf in both sync and async modes. Otherwise, you will be getting a direct link to pdf in sync mode but also a link to the .json file in the async mode.
inline optional
Set to true to get a direct link to output pdf in async mode (otherwise you will get a link to JSON with URL inside when you use async mode).
name optional
File name for the generated output. Must be a String.
expiration optional
Set the expiration time for the output link in minutes (default is 60 i.e 60 minutes or 1 hour), After this specified duration, any generated output file(s) will be automatically deleted from PDF.co temporary files storage. The maximum duration for link expiration varies based on your current subscription plan. Learn more

To store permanent input files (e.g. re-usable images, pdf templates, documents), Consider using PDF.co built-in Files Storage.
templateData optional
Set JSON as an escaped string for use as custom macros. See [this knowledgebase article](https://apidocs.pdf.co/kb/Fill%20PDF%20and%20Add%20Text%20or%20Images%20(pdf-edit-add/macros#custom-macros) for more details.
profiles optional
You can set additional and extra options using this parameter that allows you to set custom configurations, The input must be in string format.

For example, to flatten pdf form, set profiles to this value:

{ 'FlattenDocument()': [] }

See profiles samples for examples.

  • Method: POST
  • URL: /v1/pdf/edit/add

Query parameters

No query parameters accepted.

Body payload

{
    "async": false,
    "inline": true,
    "name": "f1040-form-filled",
    "url": "https://pdfco-test-files.s3.us-west-2.amazonaws.com/pdf-form/f1040.pdf",
    "fieldsString": "1;topmostSubform[0].Page1[0].f1_02[0];John A. Doe|1;topmostSubform[0].Page1[0].FilingStatus[0].c1_01[1];true|1;topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_04[0];123456789"
}

Example responses

JSON simplified /pdf/edit/add
{
    "url": "https://pdf-temp-files.s3.amazonaws.com/03c5c55183c74f8d94a4ec952e4e32ad/f1040-form-filled.pdf",
    "pageCount": 3,
    "error": false,
    "status": 200,
    "name": "f1040-form-filled",
    "remainingCredits": 60822
}

Code Snippet

CURL
curl --location --request POST 'https://api.pdf.co/v1/pdf/edit/add' \
--header 'Content-Type: application/json' \
--header 'x-api-key: ' \
--data-raw '{
    "async": false,
    "inline": true,
    "name": "f1040-form-filled",
    "url": "https://pdfco-test-files.s3.us-west-2.amazonaws.com/pdf-form/f1040.pdf",
    "fieldsString": "1;topmostSubform[0].Page1[0].f1_02[0];John A. Doe|1;topmostSubform[0].Page1[0].FilingStatus[0].c1_01[1];true|1;topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_04[0];123456789"
}'

Samples