承接 padosoft/laravel-uploadable 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

padosoft/laravel-uploadable

最新稳定版本:5.4.0

Composer 安装命令:

composer require padosoft/laravel-uploadable

包简介

Laravel package for automatic upload handling with trait

README 文档

README

Latest Version on Packagist Software License Build Status Quality Score Total Downloads

This package provides a trait that will automatic handlind upload when saving/updating/deleting any Eloquent model with upload form request.

##Requires

  • php: >=7.1
  • illuminate/database: ^5.7|^6.0|^7.0|^8.0|^9.0
  • illuminate/support: ^5.7|^6.0|^7.0|^8.0|^9.0
  • illuminate/http: ^5.7|^6.0|^7.0|^8.0|^9.0
  • padosoft/io: "^1.9",
  • padosoft/laravel-request: "^1.0|^2.0",
  • padosoft/support: "^1.6|^2.1|^3.0.4"

Installation

You can install the package via composer:

$ composer require padosoft/laravel-uploadable

Usage

Your Eloquent models should use the Padosoft\Uploadable\Uploadable trait and the Padosoft\Uploadable\UploadOptions class.

You can define getUploadOptions() method in your model.

Here's an example of how to implement the trait with implementation of getUploadOptions():

<?php

namespace App;

use Padosoft\Uploadable\Uploadable;
use Padosoft\Uploadable\UploadOptions;
use Illuminate\Database\Eloquent\Model;

class YourEloquentModel extends Model
{
    use Uploadable;
    
 /**
     * Retrive a specifice UploadOptions for this model, or return default UploadOptions
     * @return UploadOptions
     */
    public function getUploadOptions() : UploadOptions
    {
        if($this->uploadOptions){
            return $this->uploadOptions;
        }

        $this->uploadOptions = UploadOptions::create()->getUploadOptionsDefault()
            ->setUploadBasePath(public_path('upload/' . $this->getTable()))
            ->setUploadsAttributes(['image', 'image_mobile']);

        return $this->uploadOptions;
    }
}

You can specified uploads attributes with:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setUploadsAttributes(['image', 'image_mobile']);
}

You can set the base upload path for your model:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setUploadBasePath(public_path('upload/news'));
}

You can set different path for each (or for some) upload attributes in your model:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setUploadPaths(['image_mobile' => '/mobile' ]);
}

It support validation to accept files by specified list of Mime Type:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setMimeType([
          'image/gif',
          'image/jpeg',
          'image/png',
            ]);
}

By default every uploaded file will rename with 'original_name_'.$model->id.'.original_ext' but you can redefine a custom function for renaming file:

/**
 * Generate a new file name for uploaded file.
 * Return empty string if $uploadedFile is null.
 * @param \Illuminate\Http\UploadedFile $uploadedFile
 * @param String $uploadField
 * @return string
 */
public function generateNewUploadFileName(\Illuminate\Http\UploadedFile $uploadedFile, string $uploadField) : string 
{
    if($uploadField=='image'){
        return 'pippo.jpg';
    }else{
        return 'pippo_mobile.jpg';
    }
}

This class use Laravel 'local' Storage Disk for default. You can set different disk in your model:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setStorageDisk('ftp');
}

For all options see UploadOptions class.

Change log

Please see CHANGELOG for more information what has changed recently.

Testing

$ composer test

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email instead of using the issue tracker.

Credits

About Padosoft

Padosoft (https://www.padosoft.com) is a software house based in Florence, Italy. Specialized in E-commerce and web sites.

License

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

统计信息

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

GitHub 信息

  • Stars: 27
  • Watchers: 5
  • Forks: 4
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2016-08-14