diff options
Diffstat (limited to 'src/com/android/browser/search/OpenSearchSearchEngine.java')
-rw-r--r-- | src/com/android/browser/search/OpenSearchSearchEngine.java | 49 |
1 files changed, 29 insertions, 20 deletions
diff --git a/src/com/android/browser/search/OpenSearchSearchEngine.java b/src/com/android/browser/search/OpenSearchSearchEngine.java index e600aa9..0343d6e 100644 --- a/src/com/android/browser/search/OpenSearchSearchEngine.java +++ b/src/com/android/browser/search/OpenSearchSearchEngine.java @@ -17,10 +17,14 @@ package com.android.browser.search; import com.android.browser.R; -import org.apache.http.HttpResponse; -import org.apache.http.client.HttpClient; -import org.apache.http.client.methods.HttpGet; -import org.apache.http.params.HttpParams; +import java.io.InputStream; +import java.net.HttpURLConnection; +import java.net.URL; +import java.nio.charset.Charset; +import java.nio.charset.IllegalCharsetNameException; +import java.nio.charset.UnsupportedCharsetException; +import libcore.io.Streams; +import libcore.net.http.ResponseUtils; import org.apache.http.util.EntityUtils; import org.json.JSONArray; import org.json.JSONException; @@ -33,7 +37,6 @@ import android.database.Cursor; import android.net.ConnectivityManager; import android.net.NetworkInfo; import android.net.Uri; -import android.net.http.AndroidHttpClient; import android.os.Bundle; import android.provider.Browser; import android.text.TextUtils; @@ -51,9 +54,6 @@ public class OpenSearchSearchEngine implements SearchEngine { private static final String USER_AGENT = "Android/1.0"; private static final int HTTP_TIMEOUT_MS = 1000; - // TODO: this should be defined somewhere - private static final String HTTP_TIMEOUT = "http.connection-manager.timeout"; - // Indices of the columns in the below arrays. private static final int COLUMN_INDEX_ID = 0; private static final int COLUMN_INDEX_QUERY = 1; @@ -80,13 +80,8 @@ public class OpenSearchSearchEngine implements SearchEngine { private final SearchEngineInfo mSearchEngineInfo; - private final AndroidHttpClient mHttpClient; - public OpenSearchSearchEngine(Context context, SearchEngineInfo searchEngineInfo) { mSearchEngineInfo = searchEngineInfo; - mHttpClient = AndroidHttpClient.newInstance(USER_AGENT); - HttpParams params = mHttpClient.getParams(); - params.setLongParameter(HTTP_TIMEOUT, HTTP_TIMEOUT_MS); } public String getName() { @@ -167,16 +162,31 @@ public class OpenSearchSearchEngine implements SearchEngine { /** * Executes a GET request and returns the response content. * - * @param url Request URI. + * @param urlString Request URI. * @return The response content. This is the empty string if the response * contained no content. */ - public String readUrl(String url) { + public String readUrl(String urlString) { try { - HttpGet method = new HttpGet(url); - HttpResponse response = mHttpClient.execute(method); - if (response.getStatusLine().getStatusCode() == 200) { - return EntityUtils.toString(response.getEntity()); + URL url = new URL(urlString); + HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection(); + urlConnection.setRequestProperty("User-Agent", USER_AGENT); + urlConnection.setConnectTimeout(HTTP_TIMEOUT_MS); + + if (urlConnection.getResponseCode() == 200) { + final Charset responseCharset; + try { + responseCharset = ResponseUtils.responseCharset(urlConnection.getContentType()); + } catch (UnsupportedCharsetException ucse) { + Log.i(TAG, "Unsupported response charset", ucse); + return null; + } catch (IllegalCharsetNameException icne) { + Log.i(TAG, "Illegal response charset", icne); + return null; + } + + byte[] responseBytes = Streams.readFully(urlConnection.getInputStream()); + return new String(responseBytes, responseCharset); } else { Log.i(TAG, "Suggestion request failed"); return null; @@ -192,7 +202,6 @@ public class OpenSearchSearchEngine implements SearchEngine { } public void close() { - mHttpClient.close(); } private boolean isNetworkConnected(Context context) { |