Показать сообщение отдельно
  #1 (permalink)  
Старый 06.03.2021, 19:06
Профессор
Отправить личное сообщение для Manyasha Посмотреть профиль Найти все сообщения от Manyasha
 
Регистрация: 21.09.2015
Сообщений: 196

Запись аудио: нет длительности у файла
Добрый день!

Встала задача записать голосовой ответ человека, что-то похожее на аудио сообщения в месенджерах.

Использую mediaRecorder, все работает, все скачивается.
Но почему-то при воспроизведении не могу перемотать вперед (ни на страничке, ни на компе, после того как скачала).
На компе длительность в проигрывателе стоит 435 часов, хотя запись около 10 секунд.
В свойствах файла графа продолжительность пустая.

Подскажите, пожалуйста, в какую сторону копать?
Мне как-то надо самой свойство файла заполнить?

Клиентская часть:
navigator.mediaDevices.getUserMedia({ audio: true})
	.then(function(stream){
		const mediaRecorder = new MediaRecorder(stream);

		document.querySelector('#start').addEventListener('click', function(){
			mediaRecorder.start();
		});
		let audioChunks = [];
		mediaRecorder.addEventListener("dataavailable",function(event) {
			audioChunks.push(event.data);
		});

		document.querySelector('#stop').addEventListener('click', function(){
			mediaRecorder.stop();
		});

		mediaRecorder.addEventListener("stop", function() {
			const audioBlob = new Blob(audioChunks, {
				type: 'audio/wav'
			});

			let fd = new FormData();
			fd.append('voice', audioBlob);
			sendVoice(fd);
			audioChunks = [];
		});
	});
	
async function sendVoice(form) {
	let promise = await fetch(URL, {
		method: 'POST',
		body: form});
	if (promise.ok) {
		let response =  await promise.json();
		console.log(response.data);
		let audio = document.createElement('audio');
		audio.src = response.data;
		audio.controls = true;
		audio.autoplay = false;
		document.querySelector('#messages').appendChild(audio);
	}
};


На сервере:
$uploadDir = 'records/';
$typeFile = explode('/', $_FILES['voice']['type']);
$uploadFile = $uploadDir . $pass.'_'.$q.'_'.time().'.'.$typeFile[1];
if (move_uploaded_file($_FILES['voice']['tmp_name'], $uploadFile)) {
    $response = ['result'=>'OK', 'data'=>'../voice_record/' . $uploadFile];
} else {
    $response = ['result'=>'ERROR', 'data'=>''];
}

echo json_encode($response);
Ответить с цитированием