
- PHP - Home
- PHP - Roadmap
- PHP - Introduction
- PHP - Installation
- PHP - History
- PHP - Features
- PHP - Syntax
- PHP - Hello World
- PHP - Comments
- PHP - Variables
- PHP - Echo/Print
- PHP - var_dump
- PHP - $ and $$ Variables
- PHP - Constants
- PHP - Magic Constants
- PHP - Data Types
- PHP - Type Casting
- PHP - Type Juggling
- PHP - Strings
- PHP - Boolean
- PHP - Integers
- PHP - Files & I/O
- PHP - Maths Functions
- PHP - Heredoc & Nowdoc
- PHP - Compound Types
- PHP - File Include
- PHP - Date & Time
- PHP - Scalar Type Declarations
- PHP - Return Type Declarations
- PHP - Operators
- PHP - Arithmetic Operators
- PHP - Comparison Operators
- PHP - Logical Operators
- PHP - Assignment Operators
- PHP - String Operators
- PHP - Array Operators
- PHP - Conditional Operators
- PHP - Spread Operator
- PHP - Null Coalescing Operator
- PHP - Spaceship Operator
- PHP Control Statements
- PHP - Decision Making
- PHP - If…Else Statement
- PHP - Switch Statement
- PHP - Loop Types
- PHP - For Loop
- PHP - Foreach Loop
- PHP - While Loop
- PHP - Do…While Loop
- PHP - Break Statement
- PHP - Continue Statement
- PHP Arrays
- PHP - Arrays
- PHP - Indexed Array
- PHP - Associative Array
- PHP - Multidimensional Array
- PHP - Array Functions
- PHP - Constant Arrays
- PHP Functions
- PHP - Functions
- PHP - Function Parameters
- PHP - Call by value
- PHP - Call by Reference
- PHP - Default Arguments
- PHP - Named Arguments
- PHP - Variable Arguments
- PHP - Returning Values
- PHP - Passing Functions
- PHP - Recursive Functions
- PHP - Type Hints
- PHP - Variable Scope
- PHP - Strict Typing
- PHP - Anonymous Functions
- PHP - Arrow Functions
- PHP - Variable Functions
- PHP - Local Variables
- PHP - Global Variables
- PHP Superglobals
- PHP - Superglobals
- PHP - $GLOBALS
- PHP - $_SERVER
- PHP - $_REQUEST
- PHP - $_POST
- PHP - $_GET
- PHP - $_FILES
- PHP - $_ENV
- PHP - $_COOKIE
- PHP - $_SESSION
- PHP File Handling
- PHP - File Handling
- PHP - Open File
- PHP - Read File
- PHP - Write File
- PHP - File Existence
- PHP - Download File
- PHP - Copy File
- PHP - Append File
- PHP - Delete File
- PHP - Handle CSV File
- PHP - File Permissions
- PHP - Create Directory
- PHP - Listing Files
- Object Oriented PHP
- PHP - Object Oriented Programming
- PHP - Classes and Objects
- PHP - Constructor and Destructor
- PHP - Access Modifiers
- PHP - Inheritance
- PHP - Class Constants
- PHP - Abstract Classes
- PHP - Interfaces
- PHP - Traits
- PHP - Static Methods
- PHP - Static Properties
- PHP - Namespaces
- PHP - Object Iteration
- PHP - Encapsulation
- PHP - Final Keyword
- PHP - Overloading
- PHP - Cloning Objects
- PHP - Anonymous Classes
- PHP Web Development
- PHP - Web Concepts
- PHP - Form Handling
- PHP - Form Validation
- PHP - Form Email/URL
- PHP - Complete Form
- PHP - File Inclusion
- PHP - GET & POST
- PHP - File Uploading
- PHP - Cookies
- PHP - Sessions
- PHP - Session Options
- PHP - Sending Emails
- PHP - Sanitize Input
- PHP - Post-Redirect-Get (PRG)
- PHP - Flash Messages
- PHP AJAX
- PHP - AJAX Introduction
- PHP - AJAX Search
- PHP - AJAX XML Parser
- PHP - AJAX Auto Complete Search
- PHP - AJAX RSS Feed Example
- PHP XML
- PHP - XML Introduction
- PHP - Simple XML Parser
- PHP - SAX Parser Example
- PHP - DOM Parser Example
- PHP Login Example
- PHP - Login Example
- PHP - Facebook Login
- PHP - Paypal Integration
- PHP - MySQL Login
- PHP Advanced
- PHP - MySQL
- PHP.INI File Configuration
- PHP - Array Destructuring
- PHP - Coding Standard
- PHP - Regular Expression
- PHP - Error Handling
- PHP - Try…Catch
- PHP - Bugs Debugging
- PHP - For C Developers
- PHP - For PERL Developers
- PHP - Frameworks
- PHP - Core PHP vs Frame Works
- PHP - Design Patterns
- PHP - Filters
- PHP - JSON
- PHP - Exceptions
- PHP - Special Types
- PHP - Hashing
- PHP - Encryption
- PHP - is_null() Function
- PHP - System Calls
- PHP - HTTP Authentication
- PHP - Swapping Variables
- PHP - Closure::call()
- PHP - Filtered unserialize()
- PHP - IntlChar
- PHP - CSPRNG
- PHP - Expectations
- PHP - Use Statement
- PHP - Integer Division
- PHP - Deprecated Features
- PHP - Removed Extensions & SAPIs
- PHP - PEAR
- PHP - CSRF
- PHP - FastCGI Process
- PHP - PDO Extension
- PHP - Built-In Functions
PHP cURL curl_copy_handle() Function
The PHP Client URL curl_copy_handle() function is used to copy a cURL handle along with all of its preferences. The copied cURL handle represents a cURL session. After the handle is copied, it can be altered separately from the original. This includes set up multiple parameters or running queries simultaneously.
Syntax
Below is the syntax of the PHP cURL curl_copy_handle() function −
resource curl_copy_handle ( resource $ch )
Parameters
This function accepts $ch parameter which is the cURL handle resource returned by curl_init().
Return Value
The curl_copy_handle() function returns a new cURL handle which is a copy of the original handle or FALSE on failure.
PHP Version
First introduced in core PHP 5, the curl_copy_handle() function continues to function easily in PHP 7, and PHP 8.
Example 1
First we will show you the basic example of the PHP cURL curl_copy_handle() function to copy the given URL.
<?php // Create a new cURL resource $ch = curl_init(); // Set URL and other options curl_setopt($ch, CURLOPT_URL, 'http://www.tutorialspoint.com/'); curl_setopt($ch, CURLOPT_HEADER, 0); // Copy the handle $ch2 = curl_copy_handle($ch); echo "The URL handle is copied successfully." ; // Get the URL and pass it to the browser curl_exec($ch2); // Close cURL resources curl_close($ch2); curl_close($ch);
Output
Here is the outcome of the following code −
The URL handle is copied successfully.
Example 2
This is an additional PHP example code that uses the curl_copy_handle() method to copy the given URL handle and display both original and copied URL in the output.
<?php // Initialize a cURL session $ch = curl_init('https://www.tutorialspoint.com'); // Set options here curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); // Create a copy of the cURL handle $ch_copy = curl_copy_handle($ch); // Get the URL from the original handle $original_url = curl_getinfo($ch, CURLINFO_EFFECTIVE_URL); // Get the URL from the copied handle $copied_url = curl_getinfo($ch_copy, CURLINFO_EFFECTIVE_URL); // Print both URLs echo "Original URL: " . $original_url . '\n'; echo "Copied URL: " . $copied_url . "\n"; // Close both handles when done curl_close($ch); curl_close($ch_copy); ?>
Output
This will produce the following output −
Original URL: https://www.tutorialspoint.com Copied URL: https://www.tutorialspoint.com
Example 3
In the below PHP code we will try to copy the URL using the curl_copy_handle() function and modify the original URL and display the data from all the URLs.
<?php // Initialize a cURL session $ch = curl_init('https://jsonplaceholder.typicode.com/posts/1'); // Set some common options curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); // Create a copy of the cURL handle $ch_copy1 = curl_copy_handle($ch); $ch_copy2 = curl_copy_handle($ch); // Change the URL for the copies curl_setopt($ch_copy1, CURLOPT_URL, 'https://jsonplaceholder.typicode.com/posts/2'); curl_setopt($ch_copy2, CURLOPT_URL, 'https://jsonplaceholder.typicode.com/posts/3'); // Perform the requests $response1 = curl_exec($ch_copy1); $response2 = curl_exec($ch_copy2); // Print the responses echo "Response from post 2: " . $response1 . "\n"; echo "Response from post 3: " . $response2 . "\n"; // Close all handles curl_close($ch); curl_close($ch_copy1); curl_close($ch_copy2); ?>
Output
This will generate the below output −
Response from post 2: { "userId": 1, "id": 2, "title": "qui est esse", "body": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla" } Response from post 3: { "userId": 1, "id": 3, "title": "ea molestias quasi exercitationem repellat qui ipsa sit aut", "body": "et iusto sed quo iure\nvoluptatem occaecati omnis eligendi aut ad\nvoluptatem doloribus vel accusantium quis pariatur\nmolestiae porro eius odio et labore et velit aut" }
Summary
The curl_copy_handle() method is a built-in function to copy the cURL handle. This function is very helpful when you need to properly handle multiple requests at once or use the same cURL settings for multiple requests.