我正在尝试读取音乐文件的ID3标签。目前,我有一个数据范围对象,其中包含一个音频文件的最后128位(因为ID3标记在音频文件中的最后128位)。因此,在这一点上,我不知道如何进一步,如何从音频文件中读取不同的部分(标题,专辑等)?(请不要用外部脚本或库回答)
window.onload = function(){
file = $("file");
reader = new FileReader();
reader.onload = function(){
length = reader.result.byteLength
dv = new DataView(reader.result, length-128, 128);
}
file.onchange = function(e){
reader.readAsArrayBuffer(e.target.files[0]);
}
}
请检查ID3 TAG格式的结构(https://en.wikipedia.org/wiki/id3#layout),这是V1的格式:
| Field | Offset | Length | Value |
|--------|--------|--------|---------|
| Header | 0 | 3 | TAG |
| Title | 3 | 30 | |
| Artist | 33 | 30 | |
| ... ect |
- 从文件中读取128个字节。
- 创建一个阅读斑点的读者。
- 创建一个dataview以读取ArrayBuffer。
- 对于每个字段,将缓冲区转换为带有
String.fromCharCode
的字符串。
function readString(dataView, offset, length) {
var o = '';
for (var i = offset; i < offset + length; i++) {
// keep only printable characters
if (i >= 32) o += String.fromCharCode(dataView.getUint8(i));
}
return o;
}
var file = fileElm.files[0];
var blob = file.slice(file.size - 128, file.size);
var reader = new FileReader();
reader.onload = function(evt) {
var buff = evt.target.result;
var dataView = new DataView(buff)
console.log('TAG:', readString(dataView, 0, 3));
console.log('title: ', readString(dataView, 3, 30)); // title
console.log('artist: ', readString(dataView, 33, 30)); // artist
console.log('album: ', readString(dataView, 63, 30)); // album
console.log('year: ', readString(dataView, 93, 4)); // year
}
reader.readAsArrayBuffer(blob);