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]
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
You would have to parse the HTML that cUrl returned and find the links, then pull those through a new cUrl request.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With