Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xPaw/Crimp.php
⚡ A simple multi curl implementation, optimized for high concurrency.
https://github.com/xPaw/Crimp.php
concurrency curl multi-threading php
Last synced: about 2 months ago
JSON representation
⚡ A simple multi curl implementation, optimized for high concurrency.
- Host: GitHub
- URL: https://github.com/xPaw/Crimp.php
- Owner: xPaw
- License: mit
- Created: 2016-05-04T09:12:32.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-04-12T11:06:21.000Z (almost 2 years ago)
- Last Synced: 2024-11-15T14:24:32.430Z (about 2 months ago)
- Topics: concurrency, curl, multi-threading, php
- Language: PHP
- Homepage: https://packagist.org/packages/xpaw/crimp
- Size: 29.3 KB
- Stars: 25
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Crimp [![Packagist](https://img.shields.io/packagist/dt/xpaw/crimp.svg)](https://packagist.org/packages/xpaw/crimp)
A simple multi curl implementation, optimized for high concurrency.
This is practically a bare bones implemention.
Retrying, HTTP code checking and other stuff is up to the user.Usage:
```php
$Crimp = new Crimp( function( CurlHandle $Handle, string $Data, $Request ) : void
{
// $Handle is the cURL handle
// $Data is the content of a cURL handle
// $Request is whatever was queued
} );// How many concurrent threads to use
$Crimp->Threads = 10;// Set any curl option that are needed
$Crimp->CurlOptions[ CURLOPT_FOLLOWLOCATION ] = 1;// Queue urls
$Crimp->Add( 'https://example.com/?v=1' );
$Crimp->Add( 'https://example.com/?v=2' );// Queue an array, it must contain a `Url` key
$Crimp->Add( [ 'Url' => 'https://example.com/?v=3' ] );// Queue an object, it must contain a `Url` property
class RequestUrl { public string $Url; }
$request = new RequestUrl();
$request->Url = 'https://example.com/?v=4';
$Crimp->Add( $request );// Execute the requests
$Crimp->Go();
````CURLOPT_RETURNTRANSFER` is enabled by default. See [examples](examples/) folder for more.
If you need a fully featured multi cURL implemention, take a look at
[Zebra_cURL](https://github.com/stefangabos/Zebra_cURL) or [Guzzle](https://github.com/guzzle/guzzle) instead.