summaryrefslogtreecommitdiff
path: root/src/de
diff options
context:
space:
mode:
authordaniel oeh <daniel.oeh@gmail.com>2013-12-31 01:27:05 +0100
committerdaniel oeh <daniel.oeh@gmail.com>2013-12-31 01:27:05 +0100
commitbad86d8284fb48bd130370eefb8d8c7ae25ab44c (patch)
treec8eb0ae94edbc4f29fb005ae5c48f23556fbfd23 /src/de
parent999d10ae5d8fdd71358ce84148d2374b7fd93016 (diff)
downloadAntennaPod-bad86d8284fb48bd130370eefb8d8c7ae25ab44c.zip
Escape URLs in HttpDownloader. fixes #329, #332
Diffstat (limited to 'src/de')
-rw-r--r--src/de/danoeh/antennapod/service/download/HttpDownloader.java17
1 files changed, 13 insertions, 4 deletions
diff --git a/src/de/danoeh/antennapod/service/download/HttpDownloader.java b/src/de/danoeh/antennapod/service/download/HttpDownloader.java
index 582fb9575..94cf01188 100644
--- a/src/de/danoeh/antennapod/service/download/HttpDownloader.java
+++ b/src/de/danoeh/antennapod/service/download/HttpDownloader.java
@@ -6,9 +6,7 @@ import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
-import java.net.HttpURLConnection;
-import java.net.SocketTimeoutException;
-import java.net.UnknownHostException;
+import java.net.*;
import org.apache.commons.io.IOUtils;
import org.apache.http.Header;
@@ -58,13 +56,24 @@ public class HttpDownloader extends Downloader {
return httpClient;
}
+ private URI getURIFromRequestUrl(String source) {
+ try {
+ URL url = new URL(source);
+ return new URI(url.getProtocol(), url.getUserInfo(), url.getHost(), url.getPort(), url.getPath(), url.getQuery(), url.getRef());
+ } catch (MalformedURLException e) {
+ throw new IllegalArgumentException(e);
+ } catch (URISyntaxException e) {
+ throw new IllegalArgumentException(e);
+ }
+ }
+
@Override
protected void download() {
DefaultHttpClient httpClient = null;
BufferedOutputStream out = null;
InputStream connection = null;
try {
- HttpGet httpGet = new HttpGet(request.getSource());
+ HttpGet httpGet = new HttpGet(getURIFromRequestUrl(request.getSource()));
httpClient = createHttpClient();
HttpResponse response = httpClient.execute(httpGet);
HttpEntity httpEntity = response.getEntity();