dezull/unarchiver 问题修复 & 功能扩展

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

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

dezull/unarchiver

Composer 安装命令:

composer require dezull/unarchiver

包简介

Extract archives using libarchive tools and unrar

README 文档

README

This PHP library, as the name implies, only supports archive listing and extraction.

Why?

I created this specifically for my need to list the content of very large archives. Instead of returning a large array, this library returns a Generator instead. This keeps the memory usage constantly low.

Since other libraries already offer archiving and other great features, I decided not to add them here.

Installation

  1. Install dependencies (eg: Ubuntu):
sudo apt install libarchive-tools p7zip-full unrar
  1. Install the package via Composer:
composer require dezull/unarchiver

Usage

Create an instance of the unarchiver:

use Dezull\Unarchiver\Unarchiver;

$ua = Unarchiver::open('/path/to/file.zip’);

If the archive is encrypted, pass the password as the second argument.

Extraction

$ua->extract('/path/to/output-dir');

Listing Content

foreach ($ua->getEntries() as $entry) {
    // @var Dezull\Unarchiver\Entry\EntryInterface
    echo $entry->getPath().PHP_EOL;
}

API

Unarchiver

Method Return Usage
getEntries() Generator<EntryInterface>
getEntry($filename) ?EntryInterface
extract(string $outputDirectory, ?array $filenames = null, bool $overwrite = true) string[] (filenames)
setTimeout(int $seconds) Unarchiver Kill the unarchiver process after this timeout

EntryInterface

Method Return Usage
isDirectory() bool
getPath() string
getSize() ?int
getPackedSize() ?int
getModificationTime() ?DateTime
getCrc() ?string
extract(string $outputDirectory, bool $overwrite = true) void

Supported Archive Formats

Currently, this library relies on bsdtar, 7z, and unrar binaries. It supports formats handled by these binaries.

Caveats

The EntryInterface#getEntry() and EntryInterface#extract() methods use the underlying binary to pass on the specific filename. The binary may treat the filename as a pattern.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-10-03