Home Backend Development PHP Tutorial How to use cURL in PHP to make remote API calls

How to use cURL in PHP to make remote API calls

Jun 17, 2023 pm 12:45 PM
php api curl

In today's website applications, calling remote services through API has become a very common requirement. PHP provides many APIs to implement remote API calls, among which cURL is a commonly used one. Using cURL, it is very convenient to send requests to remote services and obtain corresponding data through HTTP/HTTPS protocols. This article will introduce how to use cURL in PHP to make remote API calls and provide some common application scenarios.

Installing cURL
Before you start using cURL, you first need to install the cURL module in your PHP environment. If you are using a Windows system, you can enable the cURL extension by uncomment extension=php_curl.dll in the php.ini file. If you are using a Linux or Mac system, you can install the cURL extension through the following command:

sudo apt-get install php-curl
Copy after login

or

sudo yum install php-curl
Copy after login

Then you can use cURL in PHP to send remote requests.

Send GET request
Sending a GET request using cURL is very simple. First, you need to initialize a cURL resource and set the corresponding options through the curl_setopt() function, as shown below:

$url = 'https://api.example.com/data';
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($curl);
curl_close($curl);
echo $response;
Copy after login

In the above code, we first define the URL of a remote API and use the curl_init() function A cURL resource is initialized. Then, we set the CURLOPT_URL option to the URL of the remote API, and set the CURLOPT_RETURNTRANSFER option to true, indicating that we want to return the response content of the remote API through the curl_exec() function. Finally, we close the cURL resource through the curl_close() function.

Send POST request
Using cURL to send a POST request is similar to a GET request. You only need to set the CURLOPT_POST option to true after initializing the cURL resource, and set the CURLOPT_POSTFIELDS option to the requested POST data, as shown below :

$url = 'https://api.example.com/data';
$params = array('name' => 'John Doe', 'email' => 'johndoe@example.com');
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($params));
$response = curl_exec($curl);
curl_close($curl);
echo $response;
Copy after login

In the above code, we first define the URL of a remote API and the parameters of the POST request. Then, we use the curl_init() function to initialize a cURL resource and set the CURLOPT_URL option to the URL of the remote API and the CURLOPT_RETURNTRANSFER option to true. Next, we set the CURLOPT_POST option to true and set the CURLOPT_POSTFIELDS option to the POST parameters we defined. Finally, we executed the POST request through the curl_exec() function and closed the cURL resource using the curl_close() function.

Send a request with HTTP headers
In some scenarios, we need to customize HTTP headers to send requests. At this time, we need to set the CURLOPT_HTTPHEADER option to set the HTTP header, as shown below:

$url = 'https://api.example.com/data';
$params = array('name' => 'John Doe', 'email' => 'johndoe@example.com');
$headers = array(
    'Authorization: Bearer ' . $token,
    'Content-Type: application/x-www-form-urlencoded'
);
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($params));
curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
$response = curl_exec($curl);
curl_close($curl);
echo $response;
Copy after login

In the above code, we first define the URL of a remote API and the parameters of the POST request. Then, we define an array of HTTP headers and set two HTTP headers: Authorization and Content-Type. Finally, we use the curl_setopt() function to set the CURLOPT_HTTPHEADER option to the defined HTTP header array, thereby specifying the HTTP headers we send.

Summary
Using cURL to make remote API calls is a very common technique in PHP development. In this article, we introduced how to use cURL to send GET, POST requests, and how to send requests with HTTP headers. Of course, in actual applications, there are many other options and application scenarios that need to be understood and applied in detail. I hope this article can be helpful to beginners and provide them with a good starting point.

The above is the detailed content of How to use cURL in PHP to make remote API calls. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

CakePHP Project Configuration CakePHP Project Configuration Sep 10, 2024 pm 05:25 PM

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

CakePHP Date and Time CakePHP Date and Time Sep 10, 2024 pm 05:27 PM

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

CakePHP File upload CakePHP File upload Sep 10, 2024 pm 05:27 PM

To work on file upload we are going to use the form helper. Here, is an example for file upload.

CakePHP Routing CakePHP Routing Sep 10, 2024 pm 05:25 PM

In this chapter, we are going to learn the following topics related to routing ?

Discuss CakePHP Discuss CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

CakePHP Creating Validators CakePHP Creating Validators Sep 10, 2024 pm 05:26 PM

Validator can be created by adding the following two lines in the controller.

See all articles