dev-master
9999999-devRotating proxy bundle for Symfony.
The Requires
- php >=7.1.0
- symfony/framework-bundle ~3.0
- doctrine/common ~2.0
- guzzlehttp/guzzle ~6.0
- fabpot/goutte ^3.1
- campo/random-user-agent ^1.3
The Development Requires
symfony2
Rotating proxy bundle for Symfony.
This bundle rotates through your pool of http proxies when sending subsequent requests., (*1)
composer require modstore/rotating-proxy-bundle:dev-master, (*2)
// app/AppKernel.php public function registerBundles() { return array( // ... new Modstore\RotatingProxyBundle\ModstoreRotatingProxyBundle(), // ... ); }
Add your proxy ip addresses to the db table: modstore_rotating_proxy - host: The proxy IP address - port: The proxy port - status: 1 to enable, 0 to disable, (*3)
/** @var \Symfony\Component\DomCrawler\Crawler $crawler */ $crawler = $container->get('modstore_rotating_proxy.manager')->crawlPage( 'https://github.com/modstore/RotatingProxyBundle', 'github', ['Referer' => 'https://www.google.com'] );
An instance of the Symfony dom crawler will be returned: https://symfony.com/doc/current/components/dom_crawler.html, (*4)
In order to ensure requests aren't too similar and blocked as a bot, each request will set a random user agent string. It is also a good idea to provide a "Referer" string that would be a plausible organic referrer to the page you're requesting., (*5)
The second argument is a group name. Requests are rotated within a group. Generally for all requests to a particular domain, you would set the same group name., (*6)
There's a test command to see how it works and test your requests. The text from the body of the page will be output., (*7)
php bin/console modstore_rotating_proxy:test
Optionally a url can be provided:, (*8)
php bin/console modstore_rotating_proxy:test --url='https://github.com/modstore/RotatingProxyBundle'
When the url argument is omitted, a request will be sent to whatsmyip.org., (*9)
A log of all requests is stored in the modstore_rotating_proxy_log table., (*10)
Rotating proxy bundle for Symfony.
symfony2