Невозможно воспроизвести поток MP3 с JMF - PullRequest
0 голосов
/ 27 января 2011

У меня есть пример короткого примера аудиоплеера, который работает нормально:

public class AudioTest {

    public static void main(String[] args) {
        Format input1 = new AudioFormat(AudioFormat.MPEGLAYER3);
        Format input2 = new AudioFormat(AudioFormat.MPEG);
        Format output = new AudioFormat(AudioFormat.LINEAR);
        PlugInManager.addPlugIn(
                "com.sun.media.codec.audio.mp3.JavaDecoder",
                new Format[]{input1, input2},
                new Format[]{output},
                PlugInManager.CODEC);
        try {
            Player player = Manager.createPlayer(new File("tone.mp3").toURL());
            player.start();
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
}

Теперь я хотел передать поток mp3 из сервлета с помощью:

Manager.createPlayer(new URL("http://localhost:88/media/tone.mp3"));

Сервлет получаетзапрос я открываю тестовый файл и отправляю заказчику.Проблема в том, что mp3 не воспроизводится (без звука) и вообще не выводится сообщение об ошибке.

Если я загружаю файл через браузер, файл воспроизводится правильно.

Сервлет работает следующим образом:

public class MediaSource extends HttpServlet {

    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        System.err.println(req);

        File mp3 = new File("tone.mp3");
        InputStream in = new FileInputStream(mp3);

        resp.setContentType("audio/mpeg");
        resp.addHeader("Content-Disposition",
                "attachment; filename=" + mp3.getName());

        resp.setContentLength((int) mp3.length());

        ServletOutputStream out = resp.getOutputStream();
        byte buf[] = new byte[1024];
        int n = in.read(buf, 0, 1024);
        while (n > 0) {
            out.write(buf, 0, n);
            out.flush();
            n = in.read(buf, 0, 1024);
        }

        in.close();
        out.close();
    }
}

Обновление для @ jogabonito

Это события

javax.media.TransitionEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,previous=Unrealized,current=Realizing,target=Started]
javax.media.CachingControlEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,cachingControl=com.sun.media.protocol.DataSource$CachingControl@f9f9d8,progress=102400]
javax.media.DurationUpdateEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,duration=javax.media.Time@1decdec
javax.media.RealizeCompleteEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,previous=Realizing,current=Realized,target=Started]
javax.media.TransitionEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,previous=Realized,current=Prefetching,target=Started]
javax.media.CachingControlEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,cachingControl=com.sun.media.protocol.DataSource$CachingControl@f9f9d8,progress=204800]
javax.media.CachingControlEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,cachingControl=com.sun.media.protocol.DataSource$CachingControl@f9f9d8,progress=205889]
javax.media.PrefetchCompleteEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,previous=Prefetching,current=Prefetched,target=Started]
javax.media.StartEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,previous=Prefetched,current=Started,target=Started,mediaTime=javax.media.Time@691f36,timeBaseTime=javax.media.Time@18020cc]
javax.media.EndOfMediaEvent[source=com.sun.media.content.unknown.Handler@c2ea3f,previous=Started,current=Prefetched,target=Prefetched,mediaTime=javax.media.Time@e94e92]

1 Ответ

1 голос
/ 27 января 2011

Не могли бы вы реализовать интерфейс ControllerListener и затем проверить наличие ControllerEvents. Затем мы можем узнать, на каком этапе создания игрока происходит сбой

...