Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

how to click a link using cURL.?

Tags:

curl

for example, in a web page many links are given.

forward  backward

take these two as two links. I want to first to load this page, which contains these links and click on any of those links. NOTE[I don't know the URL that's going to load after I click it as it randomly changes]

like image 527
Raabo Moosa Avatar asked Jul 30 '10 15:07

Raabo Moosa


2 Answers

This is an old post but for anyone searching for an answer, I had a similar issue and was able to solve it. I used PHP with cUrl.

The code to follow a link through cUrl is very simple.

// Create a user agent so websites don't block you
$userAgent = 'Googlebot/2.1 (http://www.google.bot.com/bot.html)';

// Create the initial link you want.
$target_url = "http://www.example.com/somepage";

// Initialize curl and following options
$ch = curl_init();
curl_setopt($ch, CURLOPT_USERAGENT, $userAgent);
curl_setopt($ch, CURLOPT_URL,$target_url);
curl_setopt($ch, CURLOPT_FAILONERROR, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_AUTOREFERER, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,true);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);


// Grab the html from the page
$html = curl_exec($ch);

// Error handling
if(!$html){
     handle error if page was not reachable, etc
     exit();
}


// Create a new DOM Document to handle scraping
$dom = new DOMDocument();
@$dom->loadHTML($html);


// get your element, you can do this numerous ways like getting by tag, id or using a DOMXPath object
// This example gets elements with id forward-link which might be a div or ul or li, etc
// It then gets all the a tags (links) within all those divs, uls, etc
// Then it takes the first link in the array of links and then grabs the href from the link
$search = $dom->getElementById('forward-link');
$forwardlink = $search->getElementsByTagName('a');
$forwardlink = $forwardlink->item(0);
$forwardlink = $getNamedItem('href');
$href = $forwardlink->textContent;


// Now that you have the link you want to follow/click to
// Set the target_url for the cUrl to the new url
curl_setopt($ch, CURLOPT_URL, $target_url);

$html = curl_exec($ch);


// do what you want with your new link!

This is an excellent tutorial to follow by the way: php curl tutorial

like image 178
Ishikawa Avatar answered Dec 16 '22 21:12

Ishikawa


You would have to parse the HTML that cUrl returned and find the links, then pull those through a new cUrl request.

like image 42
Fosco Avatar answered Dec 16 '22 20:12

Fosco