ziming / laravel-scrapingbee
A PHP Laravel Library for ScrapingBee
Fund package maintenance!
ziming
Installs: 6 039
Dependents: 0
Suggesters: 0
Security: 0
Stars: 29
Watchers: 3
Forks: 5
Open Issues: 0
Requires
- php: ^8.1
- illuminate/contracts: ^9.0||^10.0||^11.0
- spatie/laravel-package-tools: ^1.13.5
Requires (Dev)
- nunomaduro/collision: ^6.3||^7.0||^8.1.1
- orchestra/testbench: ^7.7||^8.0||^9.0
- phpunit/phpunit: ^9.5.24||^10.0||^11.0
- rector/rector: ^1.0
- spatie/laravel-ray: ^1.30
- symfony/thanks: ^1.3
- vimeo/psalm: ^5.6
README
A PHP Laravel Package for ScrapingBee
If you wanted to support my work you can use my referral link to create an account & be a paid customer of ScrapingBee.
Alternatively you can check out these other referral links where we both benefits if you are interested in what they offer:
- Cut your AWS costs by about 60% with Pump for free. My referral link gives you $250 too
- Dropbox extra 500 MB for new account
- GetResponse Email Marketing
Installation
You can install the package via composer:
composer require ziming/laravel-scrapingbee
You can publish the config file with:
php artisan vendor:publish --provider="Ziming\LaravelScrapingBee\LaravelScrapingBeeServiceProvider" --tag="laravel-scrapingbee-config"
This is the contents of the published config file:
return [ 'api_key' => env('SCRAPINGBEE_API_KEY'), 'base_url' => env('SCRAPINGBEE_BASE_URL', 'https://app.scrapingbee.com/api/v1/'), 'timeout' => env('SCRAPINGBEE_TIMEOUT', 120), ];
Usage
The Generic ScrapingBee Client
$scrapingBeeClient = Ziming\LaravelScrapingBee\LaravelScrapingBee::make(); $response = $scrapingBeeClient->blockAds() ->when(now()->weekOfMonth === 4, function (LaravelScrapingBee $scrapingBeeClient): LaravelScrapingBee { // if it is last week of the month, spam premium proxy to use up credits! return $scrapingBeeClient->premiumProxy(); }) ->jsonResponse() ->jsScenario([ ['click' => '#button_id'], ['wait' => 1000], ['wait_for' => '#slow_div'], ['scroll_x' => 1000], ['scroll_y' => 1000], ['fill' => ['#input_1','value_1']], ['evaluate' => 'console.log(window);'], ])->get('https://www.scrapingbee.com')
Look at the source code of src/LaravelScrapingBee.php
for the other methods (link below). Methods that return $this
are chainable. An example is the blockAds()
method you saw above. Meanwhile methods such as get()
, post()
, usageStatistics()
returns you an Illuminate\Http\Client\Response
object if no exceptions are thrown.
If for some reason you prefer to set all parameters at once you may wish to use the setParams() or addParams()
method. Take note that these methods simply takes in an array and sets the parameters as is. So for the methods that does something extra before setting the parameter you would have to do them yourselves now if you chose this path.
An example is shown below:
$scrapingBeeClient = Ziming\LaravelScrapingBee\LaravelScrapingBee::make(); $response = $scrapingBeeClient->setParams([ 'js_scenario' => json_encode([ 'instructions' => [ ['click' => '#button_id'], ['wait' => 1000], ['wait_for' => '#slow_div'], ['scroll_x' => 1000], ['scroll_y' => 1000], ['fill' => ['#input_1','value_1']], ['evaluate' => 'console.log(window);'] ] ]), 'block_ads' => true, 'json_response' => true, ])->get('https://www.scrapingbee.com')
The Google Search ScrapingBee Client
$googleSearchScrapingBeeClient = Ziming\LaravelScrapingBee\LaravelScrapingBeeGoogleSearch::make(); $response = $googleSearchScrapingBeeClient ->nbResults(8) ->page(1) ->search('scrapingbee') ->get();
Look at the source code of src/LaravelScrapingBeeGoogleSearch.php
for the other methods (link below).
LaravelScrapingBeeGoogleSearch.php
Testing
Currently, there are no tests. But if there are tests in the future, you can run the command below to execute the testcases.
composer test
Contributing
You may see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.