PHP获取远程.mp3文件的元数据(来自URL)

时间:2014-09-21 02:20:19

标签: php mp3 metadata

我正在尝试从远程.mp3文件中获取song name / artist name / song length / bitrate等。 as http://shiro-desu.com/scr/11.mp3

我已经尝试了 getID3 脚本,但据我所知,它不适用于远程文件,因为我收到此错误:"不支持远程文件 - 请复制文件在当地首先"

此外,这段代码:

<?php
$tag = id3_get_tag( "http://shiro-desu.com/scr/11.mp3" );
print_r($tag);
?>

也不起作用。
&#34;致命错误:在第2行和第34行的/home4/shiro/public_html/scr/index.php中调用未定义的函数id3_get_tag();

2 个答案:

答案 0 :(得分:1)

由于您没有提到错误,我正在考虑一个常见的错误案例undefined function

The error you get (undefined function) means the ID3 extension is not enabled in your PHP configuration:

如果您没有Id3扩展名文件,请检查here以获取安装信息。

答案 1 :(得分:0)

首先,我没有创建它,只是通过完整的示例使其易于理解。

您可以在此处阅读更多内容,但仅限于archive.org。 https://web.archive.org/web/20160106095540/http://designaeon.com/2012/07/read-mp3-tags-without-downloading-it/

首先,请从此处下载该库:http://getid3.sourceforge.net/

打开zip文件夹时,您会看到“ getid3”。将该文件夹保存到您的工作文件夹中。

接下来,在将要运行以下脚本的工作文件夹中创建一个名为“ temp”的文件夹。

基本上,它的工作是下载文件的前64k,然后从文件中读取元数据。

我喜欢一个简单的例子。希望对您有所帮助。

<?php

require_once("getid3/getid3.php");

$url_media = "http://example.com/myfile.mp3"

$a=getfileinfo($url_media);

echo"<pre>";

echo $a['tags']['id3v2']['album'][0] . "\n";  
echo $a['tags']['id3v2']['artist'][0] . "\n";  
echo $a['tags']['id3v2']['title'][0] . "\n";  
echo $a['tags']['id3v2']['year'][0] . "\n"; 
echo $a['tags']['id3v2']['year'][0] . "\n";  

echo "\n-----------------\n";

//print_r($a['tags']['id3v2']['album']);

echo "-----------------\n";

//print_r($a);

echo"</pre>";

function getfileinfo($remoteFile)

{

$url=$remoteFile;
$uuid=uniqid("designaeon_", true);
$file="temp/".$uuid.".mp3";
$size=0;
$ch = curl_init($remoteFile);
//==============================Get Size==========================//
$contentLength = 'unknown';
$ch1 = curl_init($remoteFile);
curl_setopt($ch1, CURLOPT_NOBODY, true);
curl_setopt($ch1, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch1, CURLOPT_HEADER, true);
curl_setopt($ch1, CURLOPT_FOLLOWLOCATION, true); //not necessary unless the file redirects (like the PHP example we're using here)
$data = curl_exec($ch1);
curl_close($ch1);
if (preg_match('/Content-Length: (\d+)/', $data, $matches)) {
$contentLength = (int)$matches[1];
$size=$contentLength;
}
//==============================Get Size==========================//


if (!$fp = fopen($file, "wb")) {
echo 'Error opening temp file for binary writing';
return false;
} else if (!$urlp = fopen($url, "r")) {
echo 'Error opening URL for reading';
return false;
}
try {
$to_get = 65536; // 64 KB
$chunk_size = 4096; // Haven't bothered to tune this, maybe other values would work better??
$got = 0; $data = null;

// Grab the first 64 KB of the file
while(!feof($urlp) && $got < $to_get) { $data = $data . fgets($urlp, $chunk_size); $got += $chunk_size; } fwrite($fp, $data); // Grab the last 64 KB of the file, if we know how big it is. 
if ($size > 0) {
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RESUME_FROM, $size - $to_get);
curl_exec($ch);
}

// Now $fp should be the first and last 64KB of the file!!

@fclose($fp);
@fclose($urlp);
} 
catch (Exception $e) {
@fclose($fp);
@fclose($urlp);
echo 'Error transfering file using fopen and cURL !!';
return false;
}

$getID3 = new getID3;
$filename=$file;
$ThisFileInfo = $getID3->analyze($filename);
getid3_lib::CopyTagsToComments($ThisFileInfo);
unlink($file);
return $ThisFileInfo;
}

?>