From d364a81d8f7c96dd925410871fc46831c8fadaad Mon Sep 17 00:00:00 2001 From: winlin Date: Mon, 19 Jan 2015 10:13:43 +0800 Subject: [PATCH] for #293, support http mp3 streaming --- trunk/src/app/srs_app_http_conn.cpp | 40 +++++++++-------------------- 1 file changed, 12 insertions(+), 28 deletions(-) diff --git a/trunk/src/app/srs_app_http_conn.cpp b/trunk/src/app/srs_app_http_conn.cpp index ef27fa2631..78e1d5e058 100644 --- a/trunk/src/app/srs_app_http_conn.cpp +++ b/trunk/src/app/srs_app_http_conn.cpp @@ -245,6 +245,10 @@ int SrsMp3StreamEncoder::initialize(SrsFileWriter* w) return ret; } + if ((ret = enc->write_header()) != ERROR_SUCCESS) { + return ret; + } + return ret; } @@ -316,22 +320,24 @@ int SrsLiveStream::serve_http(ISrsGoHttpResponseWriter* w, SrsHttpMessage* r) { int ret = ERROR_SUCCESS; - bool serve_flv_streaming = false; - bool serve_aac_streaming = false; - bool serve_mp3_streaming = false; + ISrsStreamEncoder* enc = NULL; srs_assert(entry); if (srs_string_ends_with(entry->pattern, ".flv")) { - serve_flv_streaming = true; + w->header()->set_content_type("video/x-flv"); + enc = new SrsFlvStreamEncoder(); } else if (srs_string_ends_with(entry->pattern, ".aac")) { - serve_aac_streaming = true; + w->header()->set_content_type("audio/x-aac"); + enc = new SrsAacStreamEncoder(); } else if (srs_string_ends_with(entry->pattern, ".mp3")) { - serve_mp3_streaming = true; + w->header()->set_content_type("audio/mpeg"); + enc = new SrsMp3StreamEncoder(); } else { ret = ERROR_HTTP_LIVE_STREAM_EXT; srs_error("http: unsupported pattern %s", entry->pattern.c_str()); return ret; } + SrsAutoFree(ISrsStreamEncoder, enc); // create consumer of souce. SrsConsumer* consumer = NULL; @@ -344,31 +350,9 @@ int SrsLiveStream::serve_http(ISrsGoHttpResponseWriter* w, SrsHttpMessage* r) SrsMessageArray msgs(SRS_PERF_MW_MSGS); // TODO: FIMXE: add pithy print. - - // write http header for streaming. - // use chunked encoding, for we donot specifes the content length. - if (serve_flv_streaming) { - w->header()->set_content_type("video/x-flv"); - } - if (serve_aac_streaming) { - w->header()->set_content_type("audio/x-aac"); - } // the memory writer. SrsStreamWriter writer(w); - - ISrsStreamEncoder* enc = NULL; - if (serve_flv_streaming) { - enc = new SrsFlvStreamEncoder(); - } - if (serve_aac_streaming) { - enc = new SrsAacStreamEncoder(); - } - if (serve_mp3_streaming) { - enc = new SrsMp3StreamEncoder(); - } - SrsAutoFree(ISrsStreamEncoder, enc); - if ((ret = enc->initialize(&writer)) != ERROR_SUCCESS) { return ret; }