simpsyst/uploader

It is a easy PHP upload manager for images, files and media in your application

1.0.0 2021-02-06 20:37 UTC

This package is auto-updated.

Last update: 2024-12-25 02:52:00 UTC


README

Maintainer Source Code PHP from Packagist Latest Version Software License Build Quality Score Total Downloads

Uploader is a set of small classes for sending images, files, and media received by a form of your application. The Uploader handles, validates and sends the files to your server. Image class can still handle sizes with the gd library.

Uploader é um conjunto de pequenas classes para envio de imagens, arquivos e midias recebidos por um formulário de sua aplicação. O Uploader trata, valida e envia os arquivos a seu servidor. A classe de imagem ainda consegue tratar tamanhos com a biblioteca gd.

About SimpSyst

SimpSyst is a set of small and optimized PHP components for common tasks. Held by Diego Matos and the Compusert team. With them you perform routine tasks with fewer lines, writing less and doing much more.

SimpSyst é um conjunto de pequenos e otimizados componentes PHP para tarefas comuns. Mantido por Diego Matos e a equipe Compusert. Com eles você executa tarefas rotineiras com poucas linhas, escrevendo menos e fazendo muito mais.

Highlights

  • Image simple upload (Simples envio de imagems)
  • File simple upload (Simples envio de arquivos)
  • Media simple upload (Simples envio de midias)
  • Managing directories with date schemas (Gestão de diretórios com esquema de datas)
  • Validation of images, files and media by mime-types (Valida de imagens, arquivos e mídias por mime-types)
  • Composer ready and PSR-2 compliant (Pronto para o composer e compatível com PSR-2)

Installation

Uploader is available via Composer:

"simpsyst/uploader": "dev-main"

or run

composer require simpsyst/uploader:dev-main

Documentation

For details on how to use the upload, see a sample folder in the component directory. In it you will have an example of use for each class. SimpSyst Uploader works like this:

Para mais detalhes sobre como usar o upload, veja uma pasta de exemplo no diretório do componente. Nela terá um exemplo de uso para cada classe. SimpSyst Uploader funciona assim:

Upload an Image

<?php
require __DIR__ . "/../vendor/autoload.php";

$image = new SimpSyst\Uploader\Image("uploads", "images", 600);

if ($_FILES) {
    try {
        $upload = $image->upload($_FILES['image'], $_POST['name']);
        echo "<img src='{$upload}' width='100%'>";
    } catch (Exception $e) {
        echo "<p>(!) {$e->getMessage()}</p>";
    }
}

Upload an File

<?php
require __DIR__ . "/../vendor/autoload.php";

$file = new SimpSyst\Uploader\File("uploads", "files");

if ($_FILES) {
    try {
        $upload = $file->upload($_FILES['file'], $_POST['name']);
        echo "<p><a href='{$upload}' target='_blank'>@SimpSyst</a></p>";
    } catch (Exception $e) {
        echo "<p>(!) {$e->getMessage()}</p>";
    }
}

Upload an Media

<?php
require __DIR__ . "/../vendor/autoload.php";

$media = new SimpSyst\Uploader\Media("uploads", "medias");

if ($_FILES) {
    try {
        $upload = $media->upload($_FILES['file'], $_POST['name']);
        echo "<p><a href='{$upload}' target='_blank'>@SimpSyst</a></p>";
    } catch (Exception $e) {
        echo "<p>(!) {$e->getMessage()}</p>";
    }
}

Upload by Filetype (Send)

<?php
require __DIR__ . "/../vendor/autoload.php";

$postscript = new SimpSyst\Uploader\Send("uploads", "postscript", ["application/postscript"]);

if ($_FILES) {
    try {
        $upload = $postscript->upload($_FILES['file'], $_POST['name']);
        echo "<p><a href='{$upload}' target='_blank'>@SimpSyst</a></p>";
    } catch (Exception $e) {
        echo "<p>(!) {$e->getMessage()}</p>";
    }
}

Upload Multiple

require __DIR__ . "/../vendor/autoload.php";

$image = new SimpSyst\Uploader\Image("uploads", "images");

try {
    foreach ($image->multiple("file", $_FILES) as $file) {
        $image->upload($file, "image-" . $file["name"], 1200);
    }
    echo "Success!";
} catch (Exception $exception) {
    echo "<p>(!) {$e->getMessage()}</p>";
}

Contributing

Please see CONTRIBUTING for details.

Support

Security: If you discover any security related issues, please email oi@diegomatos.com instead of using the issue tracker.

Se você descobrir algum problema relacionado à segurança, envie um e-mail para oi@diegomatos.com em vez de usar o rastreador de problemas.

Thank you

Credits

License

The MIT License (MIT). Please see License File for more information.