mitsuki/storage 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

mitsuki/storage

最新稳定版本:v1.0.0

Composer 安装命令:

composer require mitsuki/storage

包简介

A flexible and framework-agnostic storage library for managing structured records, originally built for the Mitsuki PHP framework and usable in any PHP application.

README 文档

README

Mitsuki Storage is a flexible, framework-agnostic PHP library for managing file storage and structured records. Originally built for the Mitsuki framework, it provides a clean and secure abstraction over the Symfony Filesystem component to handle uploads, persistence, and file management in any PHP application.

🚀 Features

  • Secure Uploads: Automatic unique filename generation to prevent collisions and overwrites.
  • Fluent Directory Management: Automatically handles recursive directory creation.
  • Standardized Exceptions: Robust error handling with custom FileException and FileNotFoundException.
  • Framework Agnostic: Integration-ready for Laravel, Symfony, Slim, or any vanilla PHP project.
  • Fully Tested: High-quality code base tested with Pest PHP.

📦 Installation

Install the package via Composer:

composer require mitsuki/storage

🛠 Usage

Initialization

To start, you need a base directory where files will be stored and an instance of Symfony's Filesystem.

use Mitsuki\Storage\Storage;
use Symfony\Component\Filesystem\Filesystem;

$baseDir = __DIR__ . '/storage';
$storage = new Storage(new Filesystem(), $baseDir);

Storing an Uploaded File

The store method expects a Symfony\Component\HttpFoundation\File\UploadedFile (standard in many frameworks).

try {
    // Stores file in storage/avatars/user-1/ with a secure unique name
    $absolutePath = $storage->store('avatars/user-1', $uploadedFile);
    
    echo "File saved at: " . $absolutePath;
} catch (FileException $e) {
    echo "Upload failed: " . $e->getMessage();
}

Retrieving and Checking Files

// Get the absolute path of a relative file
try {
    $path = $storage->getFile('avatars/user-1/photo.jpg');
} catch (FileNotFoundException $e) {
    // Handle error
}

// Simple existence check
if ($storage->exists('documents/report.pdf')) {
    // Logic here...
}

Deleting Files

try {
    $storage->delete('temp/old-file.txt');
} catch (FileNotFoundException $e) {
    // File not found
}

🧪 Testing

The library is tested using Pest PHP.

# Install development dependencies
composer install

# Run the test suite
vendor/bin/pest

📄 API Reference

Storage Class

Method Argument Description
store() string $path, UploadedFile $file Validates, secures, and moves an upload. Returns full path.
getFile() string $path Resolves a relative path to an absolute path.
exists() string $path Returns true if the path exists.
createDir() string $path Recursively creates directories.
delete() string $path Removes a file or directory.

👤 Author

Zgenius Matondo

⚖️ License

This project is licensed under the MIT License - see the LICENSE file for details.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-25

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固