Laravel Chunk Upload simplifies chunked uploads with support for multiple JavaScript libraries atop Laravel's file upload system, designed with a minimal memory footprint. Features include cross-domain request support, automatic cleaning, and intuitive usage.
For example repository with integration tests, visit laravel-chunk-upload-example.
Before contributing, familiarize yourself with the guidelines outlined in CONTRIBUTION.md.
1. Install via Composer
composer require pion/laravel-chunk-upload
2. Publish the Configuration (Optional)
php artisan vendor:publish --provider="Pion\Laravel\ChunkUpload\Providers\ChunkUploadServiceProvider"
The setup involves three steps:
- Integrate your controller to handle file uploads. Instructions
- Define a route for the controller. Instructions
- Select your preferred frontend provider (multiple providers are supported in a single controller).
Library | Wiki | Single & Chunk Upload | Simultaneous Uploads | Included in Example Project | Author |
---|---|---|---|---|---|
resumable.js | Wiki | ✔️ | ✔️ | ✔️ | @pionl |
DropZone | Wiki | ✔️ | ✔️ | ✔️ | @pionl |
jQuery-File-Upload | Wiki | ✔️ | ✖️ | ✔️ | @pionl |
Plupload | Wiki | ✔️ | ✖️ | ✖️ | @pionl |
simple uploader | ✖️ | ✔️ | ✖️ | ✖️ | @dyktek |
ng-file-upload | Wiki | ✔️ | ✖️ | ✖️ | @L3o-pold |
Simultaneous Uploads: The library must send the last chunk as the final one to ensure correct merging.
Custom Disk: Currently, it's recommended to use the basic storage setup (not linking the public folder). If you have time to verify its functionality, please PR the changes!
For detailed information and tips, refer to the Wiki or explore a working example in a separate repository with example.
View the changelog in releases.
Review the contribution guidelines before submitting your PRs (and utilize the example repository for running integration tests).
Refer to CONTRIBUTING.md for contribution instructions. All contributions are welcome.
Though not tested via automation scripts, Laravel 5/6 should still be supported.
Version | PHP |
---|---|
11.* | 8.2 |
10.* | 8.1, 8.2 |
9.* | 8.0, 8.1 |
8.* | 7.4, 8.0, 8.1 |
7.* | 7.4 |
laravel-chunk-upload was authored by Martin Kluska and is released under the MIT License.
Copyright (c) 2017 and beyond Martin Kluska and all contributors (Thank you ❤️)