This PHP class uploads files and manipulates images very easily

Overview

class.upload.php

Homepage : http://www.verot.net/php_class_upload.htm

Demo : http://www.verot.net/php_class_upload_samples.htm

Donations: http://www.verot.net/php_class_upload_donate.htm

Commercial use: http://www.verot.net/php_class_upload_license.htm

What does it do?

This class manages file uploads for you. In short, it manages the uploaded file, and allows you to do whatever you want with the file, especially if it is an image, and as many times as you want.

It is the ideal class to quickly integrate file upload in your site. If the file is an image, you can convert, resize, crop it in many ways. You can also apply filters, add borders, text, watermarks, etc... That's all you need for a gallery script for instance. Supported formats are PNG, JPG, GIF, WEBP and BMP.

You can also use the class to work on local files, which is especially useful to use the image manipulation features. The class also supports Flash uploaders and XMLHttpRequest.

The class works with PHP 5.3+, PHP 7 and PHP 8 (use version 1.x for PHP 4 support), and its error messages can be localized at will.

Install via composer

Edit your composer.json file to include the following:

    {
       "require": {
           "verot/class.upload.php": "*"
       }
    }

Or install it directly:

    composer require verot/class.upload.php

Demo and examples

Check out the test/ directory, which you can load in your browser. You can test the class and its different ways to instantiate it, see some code examples, and run some tests.

How to use it?

Create a simple HTML file, with a form such as:

">
<form enctype="multipart/form-data" method="post" action="upload.php">
  <input type="file" size="32" name="image_field" value="">
  <input type="submit" name="Submit" value="upload">
form>

Create a file called upload.php (into which you have first loaded the class):

$handle = new \Verot\Upload\Upload($_FILES['image_field']);
if ($handle->uploaded) {
  $handle->file_new_name_body   = 'image_resized';
  $handle->image_resize         = true;
  $handle->image_x              = 100;
  $handle->image_ratio_y        = true;
  $handle->process('/home/user/files/');
  if ($handle->processed) {
    echo 'image resized';
    $handle->clean();
  } else {
    echo 'error : ' . $handle->error;
  }
}

How does it work?

You instanciate the class with the $_FILES['my_field'] array where my_field is the field name from your upload form. The class will check if the original file has been uploaded to its temporary location (alternatively, you can instanciate the class with a local filename).

You can then set a number of processing variables to act on the file. For instance, you can rename the file, and if it is an image, convert and resize it in many ways. You can also set what will the class do if the file already exists.

Then you call the function process() to actually perform the actions according to the processing parameters you set above. It will create new instances of the original file, so the original file remains the same between each process. The file will be manipulated, and copied to the given location. The processing variables will be reset once it is done.

You can repeat setting up a new set of processing variables, and calling process() again as many times as you want. When you have finished, you can call clean() to delete the original uploaded file.

If you don't set any processing parameters and call process() just after instanciating the class. The uploaded file will be simply copied to the given location without any alteration or checks.

Don't forget to add enctype="multipart/form-data" in your form tag

if you want your form to upload the file.

Namespacing

The class is now namespaced in the Verot/Upload namespace. If you have the error Fatal error: Class 'Upload' not found, then make sure your file belongs to the namespace, or instantiate the class with its fully qualified name:

namespace Verot\Upload;
$handle = new Upload($_FILES['image_field']);

or

$handle = new \Verot\Upload\Upload($_FILES['image_field']);

How to process local files?

Instantiate the class with the local filename, as following:

$handle = new Upload('/home/user/myfile.jpg');

How to process a file uploaded via XMLHttpRequest?

Instantiate the class with the special php: keyword, as following:

$handle = new Upload('php:'.$_SERVER['HTTP_X_FILE_NAME']);

Prefixing the argument with php: tells the class to retrieve the uploaded data in php://input, and the rest is the stream's filename, which is generally in $_SERVER['HTTP_X_FILE_NAME']. But you can use any other name you see fit:

$handle = new Upload('php:mycustomname.ext');

How to process raw file data?

Instantiate the class with the special data: keyword, as following:

$handle = new Upload('data:'.$file_contents);

If your data is base64-encoded, the class provides a simple base64: keyword, which will decode your data prior to using it:

$handle = new Upload('base64:'.$base64_file_contents);

How to set the language?

Instantiate the class with a second argument being the language code:

$handle = new Upload($_FILES['image_field'], 'fr_FR');
$handle = new Upload('/home/user/myfile.jpg', 'fr_FR');

How to output the resulting file or picture directly to the browser?

Simply call process() without an argument (or with null as first argument):

$handle = new Upload($_FILES['image_field']);
header('Content-type: ' . $handle->file_src_mime);
echo $handle->process();
die();

Or if you want to force the download of the file:

process(); die();">
$handle = new Upload($_FILES['image_field']);
header('Content-type: ' . $handle->file_src_mime);
header("Content-Disposition: attachment; filename=".rawurlencode($handle->file_src_name).";");
echo $handle->process();
die();

Troubleshooting

If the class doesn't do what you want it to do, you can display the log, in order to see in details what the class does. To obtain the log, just add this line at the end of your code:

echo $handle->log;

Your problem may have been already discussed in the Frequently Asked Questions : http://www.verot.net/php_class_upload_faq.htm

Failing that, you can search in the forums, and ask a question there: http://www.verot.net/php_class_upload_forum.htm. Please don't use Github issues to ask for help.

Processing parameters

Note: all the parameters in this section are reset after each process.

File handling

  • file_new_name_body replaces the name body (default: null)
$handle->file_new_name_body = 'new name';
  • file_name_body_add appends to the name body (default: null)
$handle->file_name_body_add = '_uploaded';
  • file_name_body_pre prepends to the name body (default: null)
$handle->file_name_body_pre = 'thumb_';
  • file_new_name_ext replaces the file extension (default: null)
$handle->file_new_name_ext = 'txt';
  • file_safe_name formats the filename (spaces changed to _, etc...) (default: true)
$handle->file_safe_name = true;
  • file_force_extension forces an extension if there isn't any (default: true)
$handle->file_force_extension = true;
  • file_overwrite sets behaviour if file already exists (default: false)
$handle->file_overwrite = true;
  • file_auto_rename automatically renames file if it already exists (default: true)
$handle->file_auto_rename = true;
  • dir_auto_create automatically creates destination directory if missing (default: true)
$handle->dir_auto_create = true;
  • dir_auto_chmod automatically attempts to chmod the destination directory if not writeable (default: true)
$handle->dir_auto_chmod = true;
  • dir_chmod chmod used when creating directory or if directory not writeable (default: 0777)
$handle->dir_chmod = 0777;
  • file_max_size sets maximum upload size (default: upload_max_filesize from php.ini)
$handle->file_max_size = '1024'; // 1KB
  • mime_check sets if the class check the MIME against the allowed list (default: true)
$handle->mime_check = true;
  • no_script sets if the class turns scripts into text files (default: true)
$handle->no_script = false;
  • allowed array of allowed mime-types (or one string). wildcard accepted, as in image/* (default: check init())
$handle->allowed = array('application/pdf','application/msword', 'image/*');
  • forbidden array of forbidden mime-types (or one string). wildcard accepted, as in image/* (default: check init())
$handle->forbidden = array('application/*');

Image handling

  • image_convert if set, image will be converted (possible values : ''|'png'|'webp'|'jpeg'|'gif'|'bmp'; default: '')
$handle->image_convert = 'jpg';
  • image_background_color if set, will forcibly fill transparent areas with the color, in hexadecimal (default: null)
$handle->image_background_color = '#FF00FF';
  • image_default_color fallback color background color for non alpha-transparent output formats, such as JPEG or BMP, in hexadecimal (default: #FFFFFF)
$handle->image_default_color = '#FF00FF';
  • png_compression sets the compression level for PNG images, between 1 (fast but large files) and 9 (slow but smaller files) (default: null (Zlib default))
$handle->png_compression = 9;
  • webp_quality sets the compression quality for WEBP images (default: 85)
$handle->webp_quality = 50;
  • jpeg_quality sets the compression quality for JPEG images (default: 85)
$handle->jpeg_quality = 50;
  • jpeg_size if set to a size in bytes, will approximate jpeg_quality so the output image fits within the size (default: null)
$handle->jpeg_size = 3072;
  • image_interlace if set to true, the image will be saved interlaced (if it is a JPEG, it will be saved as a progressive PEG) (default: false)
$handle->image_interlace = true;

Image checking

The following eight settings can be used to invalidate an upload if the file is an image (note that open_basedir restrictions prevent the use of these settings)

  • image_max_width if set to a dimension in pixels, the upload will be invalid if the image width is greater (default: null)
$handle->image_max_width = 200;
  • image_max_height if set to a dimension in pixels, the upload will be invalid if the image height is greater (default: null)
$handle->image_max_height = 100;
  • image_max_pixels if set to a number of pixels, the upload will be invalid if the image number of pixels is greater (default: null)
$handle->image_max_pixels = 50000;
  • image_max_ratio if set to a aspect ratio (width/height), the upload will be invalid if the image apect ratio is greater (default: null)
$handle->image_max_ratio = 1.5;
  • image_min_width if set to a dimension in pixels, the upload will be invalid if the image width is lower (default: null)
$handle->image_min_width = 100;
  • image_min_height if set to a dimension in pixels, the upload will be invalid if the image height is lower (default: null)
$handle->image_min_height = 500;
  • image_min_pixels if set to a number of pixels, the upload will be invalid if the image number of pixels is lower (default: null)
$handle->image_min_pixels = 20000;
  • image_min_ratio if set to a aspect ratio (width/height), the upload will be invalid if the image apect ratio is lower (default: null)
$handle->image_min_ratio = 0.5;

Image resizing

  • image_resize determines is an image will be resized (default: false)
$handle->image_resize = true;

The following variables are used only if image_resize == true

  • image_x destination image width (default: 150)
$handle->image_x = 100;
  • image_y destination image height (default: 150)
$handle->image_y = 200;

Use either one of the following

  • image_ratio if true, resize image conserving the original sizes ratio, using image_x AND image_y as max sizes if true (default: false)
$handle->image_ratio = true;
  • image_ratio_crop if true, resize image conserving the original sizes ratio, using image_x AND image_y as max sizes, and cropping excedent to fill the space. setting can also be a string, with one or more from 'TBLR', indicating which side of the image will be kept while cropping (default: false)
$handle->image_ratio_crop = true;
  • image_ratio_fill if true, resize image conserving the original sizes ratio, using image_x AND image_y as max sizes, fitting the image in the space and coloring the remaining space. setting can also be a string, with one or more from 'TBLR', indicating which side of the space the image will be in (default: false)
$handle->image_ratio_fill = true;
  • image_ratio_x if true, resize image, calculating image_x from image_y and conserving the original sizes ratio (default: false)
$handle->image_ratio_x = true;
  • image_ratio_y if true, resize image, calculating image_y from image_x and conserving the original sizes ratio (default: false)
$handle->image_ratio_y = true;
  • image_ratio_pixels if set to a long integer, resize image, calculating image_y and image_x to match a the number of pixels (default: false)
$handle->image_ratio_pixels = 25000;

And eventually prevent enlarging or shrinking images

  • image_no_enlarging cancel resizing if the resized image is bigger than the original image, to prevent enlarging (default: false)
$handle->image_no_enlarging = true;
  • image_no_shrinking cancel resizing if the resized image is smaller than the original image, to prevent shrinking (default: false)
$handle->image_no_shrinking = true;

Image effects

The following image manipulations require GD2+

  • image_brightness if set, corrects the brightness. value between -127 and 127 (default: null)
$handle->image_brightness = 40;
  • image_contrast if set, corrects the contrast. value between -127 and 127 (default: null)
$handle->image_contrast = 50;
  • image_opacity if set, changes the image opacity. value between 0 and 100 (default: null)
$handle->image_opacity = 50;
  • image_tint_color if set, will tint the image with a color, value as hexadecimal #FFFFFF (default: null)
$handle->image_tint_color = '#FF0000';
  • image_overlay_color if set, will add a colored overlay, value as hexadecimal #FFFFFF (default: null)
$handle->image_overlay_color = '#FF0000';
  • image_overlay_opacity used when image_overlay_color is set, determines the opacity (default: 50)
$handle->image_overlay_opacity = 20;
  • image_negative inverts the colors in the image (default: false)
$handle->image_negative = true;
  • image_greyscale transforms an image into greyscale (default: false)
$handle->image_greyscale = true;
  • image_threshold applies a threshold filter. value between -127 and 127 (default: null)
$handle->image_threshold = 20;
  • image_pixelate pixelate an image, value is block size (default: null)
$handle->image_pixelate = 10;
  • image_unsharp applies an unsharp mask, with alpha transparency support (default: false)
$handle->image_unsharp = true;
  • image_unsharp_amount unsharp mask amount, typically 50 - 200 (default: 80)
$handle->image_unsharp_amount = 120;
  • image_unsharp_radius unsharp mask radius, typically 0.5 - 1 (default: 0.5)
$handle->image_unsharp_radius = 1;
  • image_unsharp_threshold unsharp mask threshold, typically 0 - 5 (default: 1)
$handle->image_unsharp_threshold = 0;

Image text

  • image_text creates a text label on the image, value is a string, with eventual replacement tokens (default: null)
$handle->image_text = 'test';
  • image_text_direction text label direction, either 'h' horizontal or 'v' vertical (default: 'h')
$handle->image_text_direction = 'v';
  • image_text_color text color for the text label, in hexadecimal (default: #FFFFFF)
$handle->image_text_color = '#FF0000';
  • image_text_opacity text opacity on the text label, integer between 0 and 100 (default: 100)
$handle->image_text_opacity = 50;
  • image_text_background text label background color, in hexadecimal (default: null)
$handle->image_text_background = '#FFFFFF';
  • image_text_background_opacity text label background opacity, integer between 0 and 100 (default: 100)
$handle->image_text_background_opacity = 50;
  • image_text_font built-in font for the text label, from 1 to 5. 1 is the smallest (default: 5). Value can also be a string, which represents the path to a GDF or TTF font (TrueType).
$handle->image_text_font = 4; // or './font.gdf' or './font.ttf'
  • image_text_size font size for TrueType fonts, in pixels (GD1) or points (GD1) (default: 16) (TrueType fonts only)
$handle->image_text_size = 24;
  • image_text_angle text angle for TrueType fonts, in degrees, with 0 degrees being left-to-right reading text(default: null) (TrueType fonts only)
$handle->image_text_angle = 45;
  • image_text_x absolute text label position, in pixels from the left border. can be negative (default: null)
$handle->image_text_x = 5;
  • image_text_y absolute text label position, in pixels from the top border. can be negative (default: null)
$handle->image_text_y = 5;
  • image_text_position text label position withing the image, a combination of one or two from 'TBLR': top, bottom, left, right (default: null)
$handle->image_text_position = 'LR';
  • image_text_padding text label padding, in pixels. can be overridden by image_text_padding_x and image_text_padding_y (default: 0)
$handle->image_text_padding = 5;
  • image_text_padding_x text label horizontal padding (default: null)
$handle->image_text_padding_x = 2;
  • image_text_padding_y text label vertical padding (default: null)
$handle->image_text_padding_y = 10;
  • image_text_alignment text alignment when text has multiple lines, either 'L', 'C' or 'R' (default: 'C') (GD fonts only)
$handle->image_text_alignment = 'R';
  • image_text_line_spacing space between lines in pixels, when text has multiple lines (default: 0) (GD fonts only)
$handle->image_text_line_spacing = 3;

Image transformations

  • image_auto_rotate automatically rotates the image according to EXIF data (JPEG only) (default: true, applies even if there is no image manipulations)
$handle->image_auto_rotate = false;
  • image_flip flips image, wither 'h' horizontal or 'v' vertical (default: null)
$handle->image_flip = 'h';
  • image_rotate rotates image. Possible values are 90, 180 and 270 (default: null)
$handle->image_rotate = 90;
  • image_crop crops image. accepts 4, 2 or 1 values as 'T R B L' or 'TB LR' or 'TBLR'. dimension can be 20, or 20px or 20% (default: null)
$handle->image_crop = array(50,40,30,20); OR '-20 20%'...
  • image_precrop crops image, before an eventual resizing. accepts 4, 2 or 1 values as 'T R B L' or 'TB LR' or 'TBLR'. dimension can be 20, or 20px or 20% (default: null)
$handle->image_precrop = array(50,40,30,20); OR '-20 20%'...

Image borders

  • image_bevel adds a bevel border to the image. value is thickness in pixels (default: null)
$handle->image_bevel = 20;
  • image_bevel_color1 top and left bevel color, in hexadecimal (default: #FFFFFF)
$handle->image_bevel_color1 = '#FFFFFF';
  • image_bevel_color2 bottom and right bevel color, in hexadecimal (default: #000000)
$handle->image_bevel_color2 = '#000000';
  • image_border adds a unicolor border to the image. accepts 4, 2 or 1 values as 'T R B L' or 'TB LR' or 'TBLR'. dimension can be 20, or 20px or 20% (default: null)
$handle->image_border = '3px'; OR '-20 20%' OR array(3,2)...
  • image_border_color border color, in hexadecimal (default: #FFFFFF)
$handle->image_border_color = '#FFFFFF';
  • image_border_opacity border opacity, integer between 0 and 100 (default: 100)
$handle->image_border_opacity = 50;
  • image_border_transparent adds a fading-to-transparent border to the image. accepts 4, 2 or 1 values as 'T R B L' or 'TB LR' or 'TBLR'. dimension can be 20, or 20px or 20% (default: null)
$handle->image_border_transparent = '3px'; OR '-20 20%' OR array(3,2)...
  • image_frame type of frame: 1=flat 2=crossed (default: null)
$handle->image_frame = 2;
  • image_frame_colors list of hex colors, in an array or a space separated string (default: '#FFFFFF #999999 #666666 #000000')
$handle->image_frame_colors = array('#999999',  '#FF0000', '#666666', '#333333', '#000000');
  • image_frame_opacity frame opacity, integer between 0 and 100 (default: 100)
$handle->image_frame_opacity = 50;

Image watermark

  • image_watermark adds a watermark on the image, value is a local filename. accepted files are GIF, JPG, BMP, WEBP, PNG and PNG alpha (default: null)
$handle->image_watermark = 'watermark.png';
  • image_watermark_x absolute watermark position, in pixels from the left border. can be negative (default: null)
$handle->image_watermark_x = 5;
  • image_watermark_y absolute watermark position, in pixels from the top border. can be negative (default: null)
$handle->image_watermark_y = 5;
  • image_watermark_position watermark position withing the image, a combination of one or two from 'TBLR': top, bottom, left, right (default: null)
$handle->image_watermark_position = 'LR';
  • image_watermark_no_zoom_in prevents the watermark to be resized up if it is smaller than the image (default: true)
$handle->image_watermark_no_zoom_in = false;
  • image_watermark_no_zoom_out prevents the watermark to be resized down if it is bigger than the image (default: false)
$handle->image_watermark_no_zoom_out = true;

Image reflections

  • image_reflection_height if set, a reflection will be added. Format is either in pixels or percentage, such as 40, '40', '40px' or '40%' (default: null)
$handle->image_reflection_height = '25%';
  • image_reflection_space space in pixels between the source image and the reflection, can be negative (default: null)
$handle->image_reflection_space = 3;
  • image_reflection_color reflection background color, in hexadecimal. Now deprecated in favor of image_default_color (default: #FFFFFF)
$handle->image_default_color = '#000000';
  • image_reflection_opacity opacity level at which the reflection starts, integer between 0 and 100 (default: 60)
$handle->image_reflection_opacity = 60;

Values that can be read before calling process()

  • file_src_name Source file name
  • file_src_name_body Source file name body
  • file_src_name_ext Source file extension
  • file_src_pathname Source file complete path and name
  • file_src_mime Source file mime type
  • file_src_size Source file size in bytes
  • file_src_error Upload error code
  • file_is_image Boolean flag, true if the file is a supported image type

If the file is a supported image type (and open_basedir restrictions allow it)

  • image_src_x Source file width in pixels
  • image_src_y Source file height in pixels
  • image_src_pixels Source file number of pixels
  • image_src_type Source file type (png, webp, jpg, gif or bmp)
  • image_src_bits Source file color depth

Values that can be read after calling process()

  • file_dst_path Destination file path
  • file_dst_name_body Destination file name body
  • file_dst_name_ext Destination file extension
  • file_dst_name Destination file name
  • file_dst_pathname Destination file complete path and name

If the file is a supported image type

  • image_dst_type Destination file type (png, webp, jpg, gif or bmp)
  • image_dst_x Destination file width
  • image_dst_y Destination file height

Requirements

Most of the image operations require GD. GD2 is greatly recommended

Version 1.x supports PHP 4, 5 and 7, but is not namespaced. Use it if you need support for PHP <5.3

Version 2.x supports PHP 5.3+, PHP 7 and PHP 8.

Issues
  • Can't upload without setting

    Can't upload without setting "action" on form

    when using $_SERVER['REQUEST_METHOD'] == 'POST' to handle my POST requests I simply can't instantiate a new object but I can grab my $_FILES normally (I thought thats basically what it needs to make a new object) why is that?

    opened by nulligor 15
  • IOS direct upload orientation?

    IOS direct upload orientation?

    Still having trouble with pictures shot on IOS10 with iPhone6 in portrait mode. After upload without first editing photo shows up as landscape. Should this be working properly in latest release?

    opened by wbroeke 14
  • Chrome image/x-ms-bmp problem

    Chrome image/x-ms-bmp problem

    Chrome doesn't properly handle image/x-ms-bmp mime type (see https://bugs.chromium.org/p/chromium/issues/detail?id=449489)

    It's a quick fix, if you have something better do as you want.

    opened by G4Zz0L1 12
  • Base64 Decode issue.

    Base64 Decode issue.

    Hello.

    This is probably the simplest question/issue you will ever answer but i'm stuck and cannot see what i am doing wrong regarding base64 and mimetype

                    $formData = [
                        'avatar' => $_POST['imagebase64'],
                        'pin' => $_SESSION['upin'],
                    ];
    
                    list($type, $formData['avatar']) = explode(';', $formData['avatar']);
                    list(, $data) = explode(',', $formData['avatar']);
    
                    $handle = new upload('base64:' . $formData['avatar']);
                    if ($handle->uploaded) {
                        $handle->file_new_name_body = '12345';
                        $handle->image_resize = true;
                        $handle->image_x = 200;
                        $handle->image_y = 200;
                        $handle->file_max_size = '2097152'; // 2MB
                        $handle->allowed = array('image/jpeg', 'image/png', 'image/gif');
                        $handle->process('uploads/users/');
                        if ($handle->processed) {
                            if ($this->auth->updateUserProfileImage($formData)) {
                                startHelp::flash('message', 'profile image changed', 'alert alert-success mb-0');
                                startHelp::redirect('user/settings#profile-picture');
                                $handle->clean();
                                die();
                            }
    
                            die(LANG['something-went-wrong']);
                        } else {
                            echo 'error : ' . $handle->error;
                            echo $handle->log;
                            die();
                        }
                    }
    

    This is the code but it wont upload due to the Base64 not showing the mime. See the error log below:

    system information

    • class version : 0.35dev
    • operating system : WINNT
    • PHP version : 7.2.13
    • GD version : 2.1.0
    • supported image types : png jpg gif bmp
    • open_basedir : no restriction
    • upload_max_filesize : 2M (2097152 bytes)
    • language : en_GB source is a base64 string of length 88762
    • requires a temp file ... file created temp file is: C:\Users\Jack\AppData\Local\Temp\4a485e3a90577a8cbba4df3f47c31895
    • local file OK determining MIME type
    • Checking MIME type with Fileinfo PECL extension MAGIC path defaults to C:\xampp\php/extras/magic Fileinfo PECL extension failed (finfo_open)
    • Checking MIME type with UNIX file() command UNIX file() command not availabled
    • Checking MIME type with mime.magic file (mime_content_type()) MIME type detected as application/octet-stream by mime_content_type()
    • MIME validated as application/octet-stream
    • Flash may be rewriting MIME as application/octet-stream
    • Try to guess MIME type from file extension (): doesn't look like anything known source variables
    • You can use all these before calling process() file_src_name : base64 file_src_name_body : base64 file_src_name_ext : file_src_pathname : C:\Users\Jack\AppData\Local\Temp\4a485e3a90577a8cbba4df3f47c31895 file_src_mime : application/octet-stream file_src_size : 88762 (max= 2097152) file_src_error : 0 process file to uploads/users/\
    • file size OK
    • script renamed as base64.txt!
    • error: Incorrect type of file.

    What am i doing wrong? Thankyou very much.

    This is the mime type: 

    opened by jackttcoms 11
  • Image uploading on IIS(windows) results in tmp file in given directory

    Image uploading on IIS(windows) results in tmp file in given directory

    Debian webserver works fine, when i switch to IIS the image stays at tmp file in upload directory.

    opened by raizdev 11
  • A non well formed numeric value encountered in...

    A non well formed numeric value encountered in...

    I use this code: https://www.verot.net/php_class_upload_forum.htm?php_class_upload_forum_thread_id=4617 to upload file from url, all works well, but in server logs I have errors like this: [Wed Jan 04 13:49:59.888705 2017] [fcgid:warn] [pid 30490:tid 139711553021696] [client 79.187.5.129:54907] mod_fcgid: stderr: PHP Notice: A non well formed numeric value encountered in /home/domains/mydomain/public_html/scripts/class.upload.php on line 2720, referer: http://mydomain/administrator/index.php?go=edit_page&id=7

    class.upload.php, 2720 line is: $size *= 1024;

    How can I solve this problem?

    opened by spokospace 10
  • mime_content_type(): Can only process string or stream arguments

    mime_content_type(): Can only process string or stream arguments

    sometimes , specially in laravel : $this->file_src_pathname , in line 2484 class.upload.php , is not string and to use mime_content_type function , we should change that to string , because of that I change line 2484 to :

    $this->file_src_mime = mime_content_type(strval($this->file_src_pathname));

    and it's done

    opened by datomegasherly 10
  • When resize = true, the upload is too slow

    When resize = true, the upload is too slow

    I've implemented the script, but when the resize option is true, the upload seems to be too slow to finish, even in localhost. I'm using wamp server with gd2 activated. There's any solution for this?

    opened by tiagomaker 9
  • Photos Auto Rotating

    Photos Auto Rotating

    Hey there.

    We are experiencing photos uploaded from a camera that are rotating when they shouldn't be. Swapping from portrait to landscape.

    This is happening even IF we specify $handle->image_auto_rotate = false;

    What else could be causing this to happen?

    opened by scottiericho 9
  • Animated gifs stopped working in latest version

    Animated gifs stopped working in latest version

    Hello!

    There seems to be a problem with animated gifs on latest version 0.34dev. When I'm uploading animated gifs, it converts them to static images keeping only the first frame after processing, even when mage_resize is set to false and no other manipulations are set.

    Animated gifs are working fine on version 0.33dev and older.

    My settings:

    $upload = new Upload($_FILES['new-image']);
    $upload->file_overwrite = true;
    $upload->file_auto_rename = false;
    $upload->mime_check = true;
    $upload->no_script = true;
    $upload->file_max_size = '20M';
    $upload->allowed = ['image/*'];
    $upload->image_resize = false;
    

    PHP version: 7.0.11

    It happens with any animated gif image I tried, e.g. https://gif-avatars.com/img/150x150/happy-cat.gif

    bug 
    opened by Mad182 9
  • PSR-7 UploadedFileInterface support

    PSR-7 UploadedFileInterface support

    Is this library support PSR-7 UploadedFileInterface ? I want to integrate it with slim framework 4 that is using that interface when a file is uploaded

    opened by realrecordzLab 2
  • auto rotation problem

    auto rotation problem

    Around line 3300 where exif jpeg rotation occurs, i tested it with simple mobile phone images, and my server dropped a timeout (30s). Can you change the pixel by pixel method to php imagerotate function? Thats much faster. Thanks

    opened by syddiqua 1
  • MIME validation is not foolproof

    MIME validation is not foolproof

    As you may already be aware MIME-type is not 100% fool proof.

    For example, shell-scripts such as .bat files are declared as being application/bat or application/x-bat however that's not entirely truthful in a lot of cases; their MIME is often interpreted as application/octet-stream which is allowed by default by this class as that MIME also represents other non-malicious files and/or documents.

    I'd like to propose the ability to not only forbid certain MIME types (which already exists); but also have the ability to forbid certain extensions as a fallback safety net

    $upload->forbidden_extensions = array('bat', 'exe', 'svg', 'php', 'phtml', 'dll', 'wsdl');

    If a rookie were to accidentally open a bat file that a user uploaded; the malicious potential is endless and significant beyond repair.

    opened by zanderwar 1
  • open_basedir restriction

    open_basedir restriction

    Hi there, is it possible to override the tmp path to avoid acces violations caused by open_basedir restrictions? Something like $this->handle->custom_path = 'my_new_temp_path'; This would help a lot.

    opened by labby 9
File uploads with validation and storage strategies

Upload This component simplifies file validation and uploading. Usage Assume a file is uploaded with this HTML form: <form method="POST" enctype="mult

Brandon Savage 1.7k Jan 14, 2022
Allows generate class files parse from json and map json to php object, including multi-level and complex objects;

nixihz/php-object Allows generate class files parse from json and map json to php object, including multi-level and complex objects; Installation You

zhixin 1 Oct 29, 2021
Exploiting and fixing security vulnerabilities of an old version of E-Class. Project implemented as part of the class YS13 Cyber-Security.

Open eClass 2.3 Development of XSS, CSRF, SQLi, RFI attacks/defences of an older,vulnerable version of eclass. Project implemented as part of the clas

Aristi_Papastavrou 10 Oct 26, 2021
Optimizes class loading performance by generating a single PHP file containing all of the autoloaded files.

Class Preloader for PHP This tool is used to generate a single PHP script containing all of the classes required for a specific use case. Using a sing

Class Preloader 350 Jan 5, 2022
This project is very diverse and based upon many languages and libraries such as C++, Python, JavaScript, PHP and MQTT

ADMS-Real-time-project This project is very diverse and based upon many languages and libraries such as C++, Python, JavaScript, PHP and MQTT Advance_

Nitya parikh 1 Dec 1, 2021
Perch Dashboard app for exporting content to (Kirby) text files and Kirby Blueprint files

toKirby Perch Dashboard app for exporting content to (Kirby) text files and Kirby Blueprint files. You can easily install and test it in a few steps.

R. Banus 3 Dec 17, 2021
A FREE Wordpress Plugin to compress and convert images using cwebp, jpegoptim and optipng.

Squidge Is FREE WordpPress Plugin built for developers in mind compressing and convert images using jpegoptim, optipng, cwebp, and libavif. It's extre

Ainsley Clark 9 Jan 17, 2022
A hacky PHP script to download posts, images, videos and framework grading from Parent Zone

ParentZoneDownloader A hacky PHP script to download posts, images, videos and framework grading from Parent Zone Pre-Requisites Tested on PHP 7.4, but

null 2 Sep 6, 2021
AI PHP is a wrapper for rubix ml to make AI very approachable

AI PHP Rubix Wrap A wrapper for Rubix ML to make it very approachable Example: $report = RubixService::train($data, 'column_with_label'); Where co

null 14 Sep 11, 2021
Very flexible git hook manager for php developers

CaptainHook CaptainHook is an easy to use and very flexible git hook library for php developers. It enables you to configure your git hook actions in

CaptainHook 692 Jan 18, 2022
Allow SVG images to be used in Magento CMS blocks and pages via the TinyMCE Wysiwyg Editor.

Hyvä Themes - SVG support for the Magento CMS Wysiwyg Editor Allow SVG images to be used in CMS blocks and pages via the TinyMCE Wysiwyg Editor. hyva-

Hyvä 9 Jul 22, 2021
Oui instagram - Instagram user infos and recent images embedding plugin for @textpattern

oui_instagram Easily display Instagram recent images galleries. Plugin requirements required: Textpattern CMS 4.6+. recommended: aks_cache or any part

Nicolas Morand 4 Feb 20, 2020
Very soykaf IB+BBS software. Work_In_Progress demo below.

ImoutoIB - Terrible imageboard software. But anon-san — if it's so terrible, Why should I use it? You probably shouldn't. It's not equipped to handle

ithrts 5 Jan 13, 2022
X1 - A very simple web based note solution that's designed to serve as my second brain.

X1 A very simple web based note solution that's designed to serve as my second brain. Starting Server To start the tool simply clone the repo and then

Joel Dare 10 Jan 8, 2022
Docker images for Cyber_Security hakathon 2021.

This repository contains a set of vulnerable Docker images for attacking the container environment compiled for Cyber_Security hackathon 2021. Require

null 3 Dec 18, 2021
An open source tool that lets you create a SaaS website from docker images in 10 minutes.

简体中文 Screenshots for members ( who subscribe the plan ) for admin ⚠️ This document was translated into English by deepl and can be improved by PR An o

Easy 580 Jan 13, 2022
Super simple share buttons for WordPress. No images, no css, no javascript

Developer Share Buttons A super lightweight social sharing solution using either the Web Share API or simple sharing links. Description A simple, cust

Grant Richmond 30 Dec 4, 2021
Smd imagery - A Textpattern CMS plugin for managing images in the Write panel.

smd_imagery Insert images into your Write panel. Very handy for people who run photoblog or image-heavy sites, or those who categorise images for incl

Stef Dawson 4 Jan 17, 2020