定制 struktal/struktal-file-uploads 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

struktal/struktal-file-uploads

最新稳定版本:2.0.0

Composer 安装命令:

composer require struktal/struktal-file-uploads

包简介

A PHP library to process uploaded files

README 文档

README

This is a helper library for PHP that helps to process uploaded files.

PHP stores uploaded files in the $_FILES array. However, this array is not very trivial to use for multiple file uploads. This library provides an easy way to check whether a file upload should be allowed and to get the files in a more convenient way.

Installation

To install this library, include it in your project using composer:

composer require struktal/struktal-file-uploads

Usage

Upload a single file

The following example shows how to allow the upload of a single file.

Let's assume you have a form with a file input named fileInputName:

<form method="post" enctype="multipart/form-data">
    <input type="file" name="fileInputName" id="file">
    <input type="submit" value="Upload">
</form>

In your PHP script that is called when the form is submitted, use the FileUpload class to check whether the file upload should be allowed and to get the uploaded files:

$fileUpload = new FileUpload();

// File Upload Options
$fileUpload->setInputName("fileInputName") // Set the Name of the File Input
             ->setMultiple(false) // Only allow a single File
             ->setAllowedMimeTypes(["image/jpeg", "image/png"]) // Only allow JPEG and PNG Files
             ->setMaxSize(2) // Only allow Files up to 2 MiB
             ->handleUploadedFiles();

// Check if there were Errors during the Upload
if(!($fileUpload->successful())) {
    $errors = $fileUpload->getErrors();
    return;
}

// Get the uploaded File
$uploadedFile = $fileUpload->getFiles();

If the file upload was successful, the $uploadedFile will be an array with the following structure:

[
    [0] => [
        "name" => "file.jpeg",
        "type" => "image/jpeg",
        "tmp_name" => "/tmp/php/php1h4j1o",
        "error" => 0,
        "size" => 1024
    ]
]
Upload multiple files

The following example shows how to allow the upload of multiple files.

Let's assume you have a form with a file input named fileInputName, with the multiple attribute set:

<form method="post" enctype="multipart/form-data">
    <input type="file" name="fileInputName" id="file" multiple>
    <input type="submit" value="Upload">
</form>

In your PHP script that is called when the form is submitted, use the FileUpload class to check whether the file upload should be allowed and to get the uploaded files:

$fileUpload = new FileUpload();

// File Upload Options
$fileUpload->setInputName("fileInputName") // Set the Name of the File Input
             ->setMultiple(true) // Allow multiple Files
             ->setAllowedMimeTypes(["image/jpeg", "image/png"]) // Only allow JPEG and PNG Files
             ->setMaxSize(2) // Only allow Files up to 2 MiB
             ->handleUploadedFiles();

// Check if there were Errors during the Upload
if(!($fileUpload->successful())) {
    $errors = $fileUpload->getErrors();
    return;
}

// Get the uploaded Files
$uploadedFiles = $fileUpload->getFiles();

If the file upload was successful, the $uploadedFiles will be an array with the following structure:

[
    [0] => [
        "name" => "file1.jpeg",
        "type" => "image/jpeg",
        "tmp_name" => "/tmp/php/php1h4j1o",
        "error" => 0,
        "size" => 1024
    ],
    [1] => [
        "name" => "file2.jpeg",
        "type" => "image/jpeg",
        "tmp_name" => "/tmp/php/php1h4j1o",
        "error" => 0,
        "size" => 1024
    ],
    // ...
]
File upload options

The following options can be set for the file upload:

Option Description Default
setInputName(string $inputName) Sets the name of the file input. -
setMultiple(bool $multiple) Sets whether multiple files should be allowed. false
setAllowedMimeTypes(array $allowedMimeTypes) Sets the allowed mime types. [] (All uploads will be rejected)
setMaxSize(int $maxSize) Sets the maximum size of the file in MiB. (No maximum size)
Upload errors

You can check whether there were errors during the file upload with the successful() method. It returns true if there were no errors and false if there was at least one error.

Errors that occur during the file upload can be retrieved with the getErrors() method. It returns them as Enum values of the UploadError class. There are the following errors:

Error Code Description
UPLOAD_ERR_NOT_UPLOADED 0 The file was not uploaded via HTTP POST or the PHP upload error is not UPLOAD_ERR_OK.
UPLOAD_ERR_TYPE 1 The file type is not allowed.
UPLOAD_ERR_SIZE 2 The file size is too large.
UPLOAD_ERR_MULTIPLE 3 Multiple files were uploaded, but only a single file is allowed.

统计信息

  • 总下载量: 857
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-16