So what is cURL anyway? cURL stands for “Client URL", and it is a
library of functions that can be used to connect through a wide range of
protocols, such as HTTP, FTP, telnet and so on. cURL also speaks HTTPS,
so it can be used to communicate with secure servers.
What we are
going to use is, cURL HTTP. cURL supports POST and GET methods, file
uploads, cookies, user/password authentications, even using proxy
servers for connecting.
It can literally be used to
programmatically simulate browsing behavior. It can connect to a remote
site, login by posting username and password to the login form or by
using HTTP authentication, then retrieve pages or upload files. All of
this using pure PHP code.
So how do I use cURL to post data?
Begin by creating a new connection.
A
new connection is created using curl_init() function, which takes the
target URL as parameter (The URL where we want to post our data). The
target URL is same as the "action" parameters of a normal form, which
would look like this:
Now let's set some options for our connection. We can do this using the curl_setopt() function. Go to
curl_setopt() reference page for more information on curl_setopt() and a complete list of options.
What options do we set here?
First,
we set the connection timeout to 30 seconds, so we don't have our
script waiting indefinitely if the remote server fails to respond.
Then
we set how cURL will identify itself to the remote server. Some servers
will return different content for different browsers (or agents, such
as spiders of the search engines), so we want our request to look like
it is coming from a popular browser.
CURLOPT_RETURNTRANSFER
set to true forces cURL not to display the output of the request, but return it as a string.
Then we set CURLOPT_SSL_VERIFYPEER
option to false, so the request will not trigger an error in case of an invalid, expired or not signed SSL certificate.
Finally, we set CURLOPT_FOLLOWLOCATION
to 1 to instruct cURL to follow "Location: " redirects found in the headers sent by the remote site.
Now
we must prepare the data that we want to post. We can first store this
in an array, with the key of an element being the same as the input name
of a regular form, and the value being the value that we want to post
for that field.
For example,if in a regular form we would have:
we add this to our array like this:
Do the same for every form field.
Data will be posted in the following format:
key1=value1&key2=ವಲುಎ೨
In
order to format the data like this, we are going to create strings for
each key-value pair (for example key1=value1), put them in another array
($post_items) then combine them in one string using PHP function
implode() .
Next, we need to tell cURL which string we want to post. For this, we use the CURLOPT_POSTFIELDS option.
Finally, we execute the post, then close the connection.
By now, the data should have been posted to the remote URL. Go check this, and if it did not work properly, use curl_getinfo()
function to see any errors that might have occurred.
This line displays an array of information regarding the transfer. This must be used before closing the connection with curl_close()
;
You can also see number and description of the error by outputting curl_errno($curl_connection)
and curl_error($curl_connection)
.
So let's put everything together. Here is our code:
Post form data without using cURL
If
your hosting server does not come with cURL installed (though this is
rare as cURL is installed on most commercial hosting servers) and you
also don’t have access to server in order to install it, there are
alternatives.
One of them is using PHP’s functions fsockopen()
and fputs()
to send properly formatted data to a remote server. Here is a sample of code that does just this:
$post_data [ 'firstName' ] = 'Name' ; |
$post_data [ 'action' ] = 'Register' ; |
foreach ( $post_data as $key => $value ) { |
$post_items [] = $key . '=' . $value ; |
$post_string = implode ( '&' , $post_items ); |
$post_string = '?' . $post_string ; |
$data_length = strlen ( $post_string ); |
$connection = fsockopen ( 'www.domainname.com' , 80); |
fputs ( $connection , "POST /target_url.php HTTP/1.1\r\n" ); |
fputs ( $connection , "Host: www.domainname.com \r\n" ); |
"Content-Type: application/x-www-form-urlencoded\r\n" ); |
fputs ( $connection , "Content-Length: $data_length\r\n" ); |
fputs ( $connection , "Connection: close\r\n\r\n" ); |
fputs ( $connection , $post_string ); |
?>