HTTP Request#
The HTTP Request node is one of the most versatile nodes in n8n. It allows you to make HTTP requests to query data from any app or service with a REST API.
When using this node, you're creating a REST API call. You need some understanding of basic API terminology and concepts.
There are two ways to create an HTTP request: configure the node fields or import a curl command.
Credentials
Refer to HTTP Request credentials for guidance on setting up authentication.
Node parameters#
Method#
Select the method to use for the request:
- DELETE
- GET
- HEAD
- OPTIONS
- PATCH
- POST
- PUT
URL#
Enter the endpoint you want to use.
Authentication#
n8n recommends using the Predefined Credential Type option when it's available. It offers an easier way to set up and manage credentials, compared to configuring generic credentials.
Predefined credentials#
Credentials for integrations supported by n8n, including both built-in and community nodes. Use Predefined Credential Type for custom operations without extra setup. Refer to Custom API operations for more information.
Generic credentials#
Credentials for integrations not supported by n8n. You'll need to manually configure the authentication process, including specifying the required API endpoints, necessary parameters, and the authentication method.
You can select one of the following methods:
- Basic auth
- Custom auth
- Digest auth
- Header auth
- OAuth1 API
- OAuth2 API
- Query auth
Refer to HTTP request credentials for more information on setting up each credential type.
Parameters, headers, and body#
You can choose to send extra information with your request. The data you need to send depends on the API you're interacting with, and the request you're making. Refer to your service's API documentation for detailed guidance.
- Send Query Parameters: Include query parameters. Use query parameters as filters or searches on your query.
- Send Headers: Include request headers. Headers contain metadata about your request.
- Send Body: Send extra information in the body of your request.
Node options#
Select Add Option to view and select these options.
- Batching: Control how to batch large numbers of input items.
- Ignore SSL Issues: Download the response even if SSL certificate validation fails.
- Redirects: Choose whether to follow redirects. Enabled by default.
- Response: Provide settings about the expected API response.
- Pagination: Handle query results that are too big for the API to return in a single call. Refer to Pagination for more information.
- Proxy: Use this if you need to specify an HTTP proxy.
- Timeout: Set a timeout for the request in milliseconds.
Pagination#
Use this option to paginate results.
Inspect the API data first
Some options for pagination require knowledge of the data returned by the API you're using. Before setting up pagination, either check the API documentation, or do an API call without pagination, to see the data it returns.
Understand pagination
Pagination means splitting a large set of data into multiple pages. The amount of data on each page depends on the limit you set.
For example, you make an API call to an endpoint called /users
. The API wants to send back information on 300 users, but this is too much data for the API to send in one response.
If the API supports pagination, you can incrementally fetch the data. To do this, you call /users
with a pagination limit, and a page number or URL to tell the API which page to send. In this example, say you use a limit of 10, and start from page 0. The API sends the first 10 users in its response. You then call the API again, increasing the page number by 1, to get the next 10 results.
Configure the pagination settings:
- Pagination Mode:
- Off: Turn off pagination.
- Update a Parameter in Each Request: Use this when you need to dynamically set parameters for each request.
- Response Contains Next URL: Use this when the API response includes the URL of the next page. Use an expression to set Next URL.
For example setups, refer to HTTP Request node cookbook | Pagination.
n8n provides built-in variables for working with HTTP node requests and responses when using pagination:
Variable | Description |
---|---|
$pageCount |
The pagination count. Tracks how many pages the node has fetched. |
$request |
The request object sent by the HTTP node. |
$response |
The response object from the HTTP call. Includes $response.body , $response.headers , and $response.statusCode . The contents of body and headers depend on the data sent by the API. |
API differences
Different APIs implement pagination in different ways. Check the API documentation for the API you're using for details. You need to find out things like:
- Does the API provide the URL for the next page?
- Are there API-specific limits on page size or page number?
- The structure of the data that the API returns.
Templates and examples#
Import curl command#
curl is a command line tool and library for transferring data with URLs.
You can use curl to call REST APIs. If the API documentation of the service you want to use provides curl examples, you can copy them out of the documentation and into n8n to configure the HTTP Request node.
Import a curl command:
- Select Import cURL command.
- Paste in your curl command.
- Select Import. n8n loads the request configuration into the node fields. This overwrites any existing configuration.
Ask AI to configure the HTTP node#
From n8n version 1.40.0, you can use AI to configure the node parameters:
- Select Ask AI.
- Enter the Service and Request you want to use. For example, to use the NASA API to get their picture of the day, enter
NASA
in Service andget picture of the day
in Request. - Check the parameters: the AI tries to fill them out, but you may still need to adjust or correct the configuration.
For Cloud users, n8n provides a customized knowledge base of API specifications for the AI to draw on to provide good results. For services that aren't in the knowledge base, n8n falls back on OpenAI GPT-4's default knowledge. You can view the list of services in the knowledge base.
Self-hosted users need to enable AI features and provide their own API keys. On self-hosted, you don't have access to n8n's API specifications knowledge base, so all responses from the AI use OpenAI GPT-4's default knowledge.