File uploads with validation and storage strategies

Added by: Sam Deering





Stars: 1301

Watchers: 1301

Forks: 242

Module Description


Build Status Latest Version Total Downloads

This component simplifies file validation and uploading.


Assume a file is uploaded with this HTML form:

<form method="POST" enctype="multipart/form-data">
    <input type="file" name="foo" value=""/>
    <input type="submit" value="Upload File"/>

When the HTML form is submitted, the server-side PHP code can validate and upload the file like this:

$storage = new \Upload\Storage\FileSystem('/path/to/directory');
$file = new \Upload\File('foo', $storage);

// Optionally you can rename the file on upload
$new_filename = uniqid();

// Validate file upload
// MimeType List => http://www.iana.org/assignments/media-types/media-types.xhtml
    // Ensure file is of type "image/png"
    new \Upload\Validation\Mimetype('image/png'),

    //You can also add multi mimetype validation
    //new \Upload\Validation\Mimetype(array('image/png', 'image/gif'))

    // Ensure file is no larger than 5M (use "B", "K", M", or "G")
    new \Upload\Validation\Size('5M')

// Access data about the file that has been uploaded
$data = array(
    'name'       => $file->getNameWithExtension(),
    'extension'  => $file->getExtension(),
    'mime'       => $file->getMimetype(),
    'size'       => $file->getSize(),
    'md5'        => $file->getMd5(),
    'dimensions' => $file->getDimensions()

// Try to upload file
try {
    // Success!
} catch (\Exception $e) {
    // Fail!
    $errors = $file->getErrors();

How to Install

Install composer in your project:

curl -s https://getcomposer.org/installer | php

Require the package with composer:

php composer.phar require codeguy/upload


Josh Lockhart


MIT Public License

Module stats last updated: 2017-02-23 15:00:07

Disclaimer: Some data on this page may have been gathered from the authors GitHub respository. If you see any mistakes or outdated information please let us know. Thanks!