[FFmpeg-devel] [PATCH] avformat/http: support relative url redirection

Zhang Rui bbcallen at gmail.com
Thu Jul 4 11:18:52 CEST 2013


From: Zhang Rui <bbcallen at gmail.com>

see also http://tools.ietf.org/html/draft-ietf-httpbis-p2-semantics-17#section-9.5
---
 libavformat/http.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/libavformat/http.c b/libavformat/http.c
index be82352..0c26cd5 100644
--- a/libavformat/http.c
+++ b/libavformat/http.c
@@ -298,6 +298,7 @@ static int process_line(URLContext *h, char *line, int line_count,
 {
     HTTPContext *s = h->priv_data;
     char *tag, *p, *end;
+    char redirected_location[MAX_URL_SIZE];
 
     /* end of header */
     if (line[0] == '\0') {
@@ -337,7 +338,8 @@ static int process_line(URLContext *h, char *line, int line_count,
         while (av_isspace(*p))
             p++;
         if (!av_strcasecmp(tag, "Location")) {
-            av_strlcpy(s->location, p, sizeof(s->location));
+            ff_make_absolute_url(redirected_location, sizeof(redirected_location), s->location, p);
+            av_strlcpy(s->location, redirected_location, sizeof(s->location));
             *new_location = 1;
         } else if (!av_strcasecmp (tag, "Content-Length") && s->filesize == -1) {
             s->filesize = strtoll(p, NULL, 10);
-- 
1.8.2.1



More information about the ffmpeg-devel mailing list