Download the PHP package armonia-tech/goutte without Composer
On this page you can find all versions of the php package armonia-tech/goutte. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download armonia-tech/goutte
More information about armonia-tech/goutte
Files in armonia-tech/goutte
Package goutte
Short Description A simple PHP Web Scraper
License MIT
Homepage https://github.com/armonia-tech/Goutte
Informations about the package goutte
This is Armonia Tech fork project to solve mobile user agent issue.
Installation:
composer require armonia-tech/goutte
Usage:
Refer below
Goutte, a simple PHP Web Scraper
Goutte is a screen scraping and web crawling library for PHP.
Goutte provides a nice API to crawl websites and extract data from the HTML/XML responses.
Requirements
Goutte depends on PHP 5.5+ and Guzzle 6+.
Installation
Add fabpot/goutte
as a require dependency in your composer.json
file:
composer require fabpot/goutte
Usage
Create a Goutte Client instance (which extends
Symfony\Component\BrowserKit\Client
):
use Goutte\Client;
$client = new Client();
Make requests with the request()
method:
// Go to the symfony.com website
$crawler = $client->request('GET', 'https://www.symfony.com/blog/');
The method returns a Crawler
object
(Symfony\Component\DomCrawler\Crawler
).
To use your own Guzzle settings, you may create and pass a new Guzzle 6 instance to Goutte. For example, to add a 60 second request timeout:
use Goutte\Client;
use GuzzleHttp\Client as GuzzleClient;
$goutteClient = new Client();
$guzzleClient = new GuzzleClient(array(
'timeout' => 60,
));
$goutteClient->setClient($guzzleClient);
Click on links:
// Click on the "Security Advisories" link
$link = $crawler->selectLink('Security Advisories')->link();
$crawler = $client->click($link);
Extract data:
// Get the latest post in this category and display the titles
$crawler->filter('h2 > a')->each(function ($node) {
print $node->text()."\n";
});
Submit forms:
$crawler = $client->request('GET', 'https://github.com/');
$crawler = $client->click($crawler->selectLink('Sign in')->link());
$form = $crawler->selectButton('Sign in')->form();
$crawler = $client->submit($form, array('login' => 'fabpot', 'password' => 'xxxxxx'));
$crawler->filter('.flash-error')->each(function ($node) {
print $node->text()."\n";
});
More Information
Read the documentation of the BrowserKit and DomCrawler Symfony Components for more information about what you can do with Goutte.
Pronunciation
Goutte is pronounced goot
i.e. it rhymes with boot
and not out
.
Technical Information
Goutte is a thin wrapper around the following fine PHP libraries:
- Symfony Components: BrowserKit, CssSelector and DomCrawler;
- Guzzle HTTP Component.
License
Goutte is licensed under the MIT license.
All versions of goutte with dependencies
symfony/browser-kit Version ~2.1|~3.0|~4.0
symfony/css-selector Version ~2.1|~3.0|~4.0
symfony/dom-crawler Version ~2.1|~3.0|~4.0
guzzlehttp/guzzle Version ^6.0