rogerthomas84 / ohupload
An easy to use file upload class
dev-master
2014-12-19 15:32 UTC
Requires
- php: >=5.3.2
This package is auto-updated.
Last update: 2024-11-16 01:31:39 UTC
README
OhUpload PHP Library
PHP Uploads Made Easy!
Basic Usage
You can run a working example of this file by looking in the example
folder.
<?php $instance = new Upload('form_file_name'); $instance->setTargetDirectory('/path/to/upload/directory'); try { if ($instance->receive() === true) { // OK. $finalPath = $instance->getFinalPath(); } else { // Not OK! } } catch (\Exception $e) { // Something happened, possibly a validator. Take a look in: // \OhUpload\Validate\Exception for possible Exceptions. }
Adding a custom validator
You can easily add a validator to the validation stack. Below is an example of a custom validator.
All custom validators must extend \OhUpload\Validate\ValidateBase
and override the isValid()
method. The expected return
from the isValid()
method has to be either:
\Exception
- don't throw, just return.bool(true)
<?php namespace My\Custom\Validators; use OhUpload\Validate\ValidateBase use My\Custom\Validators\Exception\ExampleException; class MyBasicCheck extends ValidateBase { /** * Run a custom validator. * @return * \My\Custom\Validators\Exception\ExampleException * boolean true */ public function isValid() { if (!empty($this->file)) { // The file from the $_FILES array return true; } return new ExampleException('Validation failed'); } }
To add it into the process, simply use:
<?php $instance = new Upload('form_file_name'); $instance->setTargetDirectory('/path/to/upload/directory'); $instance->addValidator('/My/Custom/Validators/MyBasicCheck'); // This is a string, not an instance. try { if ($instance->receive() === true) { // OK. $finalPath = $instance->getFinalPath(); } else { // Not OK! } } catch (\My\Custom\Validators\MyBasicCheck $e) { // Wow! You're custom validator failed! }