hazel/ytdlphp 问题修复 & 功能扩展

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

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

hazel/ytdlphp

最新稳定版本:v1.0.1

Composer 安装命令:

composer require hazel/ytdlphp

包简介

A typed PHP 8.5+ wrapper for the yt-dlp command-line tool

README 文档

README

A typed PHP 8.5+ library for yt-dlp.

Build command-line arguments with a fluent API, run yt-dlp via Tempest Process, and parse JSON metadata into typed objects. URLs are validated with PHP's built-in URI extension (WHATWG).

Requirements

  • PHP 8.5+
  • Extensions: json, uri
  • yt-dlp installed and available on PATH (or configured explicitly)

Installation

composer require hazel/ytdlphp

Quick start

use Ytdlphp\Options;
use Ytdlphp\YtDlp;

$ytDlp = new YtDlp();

$ytDlp->download(
    'https://www.youtube.com/watch?v=dQw4w9WgXcQ',
    Options::create()
        ->format('bestvideo+bestaudio')
        ->output('%(title)s.%(ext)s'),
);

$info = $ytDlp->extractInfo('https://www.youtube.com/watch?v=dQw4w9WgXcQ');

echo $info->title;
echo $info->url?->toAsciiString();

Configuration

use Ytdlphp\Options;
use Ytdlphp\YtDlp;

$ytDlp = new YtDlp()
    ->withBinary('/usr/local/bin/yt-dlp')
    ->withWorkingDirectory('/tmp/downloads')
    ->withTimeout(300)
    ->withDefaultOptions(Options::create()->noWarnings());

Options builder

Options provides typed methods for common yt-dlp flags, backed by enums where useful:

use Ytdlphp\Option\AudioFormat;
use Ytdlphp\Option\Browser;
use Ytdlphp\Options;

$options = Options::create()
    ->extractAudio()
    ->audioFormat(AudioFormat::Mp3)
    ->cookiesFromBrowser(Browser::Firefox)
    ->noPlaylist()
    ->merge($extraOptions);

Use option() for flags not covered by a dedicated method.

URLs

Pass strings or Uri\WhatWg\Url instances. Strings are validated before yt-dlp runs:

use Uri\WhatWg\Url;
use Ytdlphp\UrlParser;

$url = UrlParser::parse('https://example.com/watch?v=abc');
$ytDlp->extractInfo($url);

$mediaUrls = $ytDlp->getUrls('https://example.com/watch?v=abc');
foreach ($mediaUrls as $mediaUrl) {
    echo $mediaUrl->toAsciiString();
}

Testing

composer test

License

MIT. See LICENSE.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-06-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固