У меня есть сервер узлов, который обслуживает запрос диапазона байтов из браузера. Браузер отправляет запрос. Я получаю 206 успешного кода состояния запроса байтового уровня. Но полученный сегмент не играет в видео элементе HTML5. Я использую Firefox. < /P>
Ошибка: нет видео с поддерживаемым форматом или типом MIME < /p>
async function fetchRange(url, startByte, endByte) {
try {
const response = await fetch(url, {
headers: {'Range': `bytes=${startByte}-${endByte}`}
});
const data = await response.blob();
console.log(`Fetched ${data.size} bytes from ${startByte} to ${endByte}.`);
return data;
} catch (error) {
console.error('Error fetching range:', error);
}
}
// Example usage:
const fileUrl = 'http://localhost:8000/video'; // Replace with your file URL
const start = 0;
const end = 1023; // Requesting the first 1024 bytes (0-1023)
fetchRange(fileUrl, start, end)
.then(data => {
if (data) {
// Process the received data (e.g., display it, save it)
console.log('Received data:', data);
let f = new File([data],'haah',{ type: "video/mp4" })
document.getElementById('vid2').src = URL.createObjectURL(f)
}
});
< /code>
html: < /p>
Sorry, not supported by browser
< /code>
Код сервера узлов: < /p>
if(req.url === '/video' && req.method === 'GET'){
console.log('video get')
//var filePath = 'audiofile2.flac';
var filePath = "output_ah.mp4"
var stat = fs.statSync(filePath);
var total = stat.size;
console.log(req.headers.range)
var range = req.headers.range;
var parts = range.replace(/bytes=/, "").split("-");
var partialstart = parts[0];
var partialend = parts[1];
var start = parseInt(partialstart, 10);
var end = partialend ? parseInt(partialend, 10) : total-1;
//console.log(start,end)
var chunksize = (end-start)+1;
var file = fs.createReadStream(filePath, {start: start, end: end});
res.writeHead(206, {
'Content-Range': 'bytes ' + start + '-' + end + '/' + total,
// 'Content-Length' : total,
'Accept-Ranges': 'bytes',
'Content-Length': chunksize,
'Content-Type': 'video/mp4'
// 'ETag' : '"'+"abcd-efgh"+'"'
});
file.pipe(res)
}
Подробнее здесь: https://stackoverflow.com/questions/797 ... video-elem
Извлекаемые видеоданные с использованием http -запроса байта не воспроизводятся в видеоэлементе HTML5 ⇐ Javascript
Форум по Javascript
1758320560
Anonymous
У меня есть сервер узлов, который обслуживает запрос диапазона байтов из браузера. Браузер отправляет запрос. Я получаю 206 успешного кода состояния запроса байтового уровня. Но полученный сегмент не играет в видео элементе HTML5. Я использую Firefox. < /P>
Ошибка: нет видео с поддерживаемым форматом или типом MIME < /p>
async function fetchRange(url, startByte, endByte) {
try {
const response = await fetch(url, {
headers: {'Range': `bytes=${startByte}-${endByte}`}
});
const data = await response.blob();
console.log(`Fetched ${data.size} bytes from ${startByte} to ${endByte}.`);
return data;
} catch (error) {
console.error('Error fetching range:', error);
}
}
// Example usage:
const fileUrl = 'http://localhost:8000/video'; // Replace with your file URL
const start = 0;
const end = 1023; // Requesting the first 1024 bytes (0-1023)
fetchRange(fileUrl, start, end)
.then(data => {
if (data) {
// Process the received data (e.g., display it, save it)
console.log('Received data:', data);
let f = new File([data],'haah',{ type: "video/mp4" })
document.getElementById('vid2').src = URL.createObjectURL(f)
}
});
< /code>
html: < /p>
Sorry, not supported by browser
< /code>
Код сервера узлов: < /p>
if(req.url === '/video' && req.method === 'GET'){
console.log('video get')
//var filePath = 'audiofile2.flac';
var filePath = "output_ah.mp4"
var stat = fs.statSync(filePath);
var total = stat.size;
console.log(req.headers.range)
var range = req.headers.range;
var parts = range.replace(/bytes=/, "").split("-");
var partialstart = parts[0];
var partialend = parts[1];
var start = parseInt(partialstart, 10);
var end = partialend ? parseInt(partialend, 10) : total-1;
//console.log(start,end)
var chunksize = (end-start)+1;
var file = fs.createReadStream(filePath, {start: start, end: end});
res.writeHead(206, {
'Content-Range': 'bytes ' + start + '-' + end + '/' + total,
// 'Content-Length' : total,
'Accept-Ranges': 'bytes',
'Content-Length': chunksize,
'Content-Type': 'video/mp4'
// 'ETag' : '"'+"abcd-efgh"+'"'
});
file.pipe(res)
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79770003/fetched-video-data-using-byte-range-http-request-not-playing-in-html5-video-elem[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия