Używam HttpClient dla żądań HTTPS, który działa dobrze do tej pory. Po uaktualnieniu do usługi ICS niektórzy użytkownicy zgłaszają problemy z połączeniami 3G.Android: Schemat "http" niezarejestrowany w ICS 4.0.4 w/proxy
EDYCJA: Większość z nich wydaje się używać proxy, i mogę odtworzyć to lokalnie z T-Mobile SIM przy użyciu ich proxy.
Kłody mają ten ślad stosu:
java.lang.IllegalStateException: Scheme 'http' not registered.
org.apache.http.conn.scheme.SchemeRegistry.getScheme(SchemeRegistry.java:80)
org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:126)
org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
Naszym punktem końcowym HTTPS tylko, więc nie zarejestrować końcowy HTTP w naszej SchemeRegistry celowo. Nie ma nigdzie (AFAIK), gdzie przekierowujemy do HTTP.
Oto kod, który konfiguruje httpclient dla klienta https:
DefaultHttpClient ret = null;
// sets up parameters
HttpParams params = new BasicHttpParams();
HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset(params, "utf-8");
params.setBooleanParameter("http.protocol.expect-continue", false);
HttpConnectionParams.setConnectionTimeout(params, DEFAULT_CONN_TIMEOUT_MSEC);
HttpConnectionParams.setSoTimeout(params, timeoutMsec);
HttpConnectionParams.setStaleCheckingEnabled(params, true);
SchemeRegistry registry = new SchemeRegistry();
final SocketFactory sslSocketFactory = getPreferredSSLSocketFactory();
registry.register(new Scheme("https", sslSocketFactory, 443));
ThreadSafeClientConnManager manager = new ThreadSafeClientConnManager(params, registry);
ret = new DefaultHttpClient(manager, params);
// for preemptive authentication
// http://dlinsin.blogspot.com/2009/08/http-basic-authentication-with-android.html
ret.addRequestInterceptor(preemptiveAuth, 0);
ret.setCookieStore(communalCookieJar);
SimpleCredentialsProvider credProvider = new SimpleCredentialsProvider(getAccountPreferences());
ret.setCredentialsProvider(credProvider);
return ret;
Uwaga: Dzielimy tę instancję httpclient wśród wielu wątków.
Co to jest BYPASS_PROXY? Dlaczego nie zawsze możemy skorzystać z tego planowania trasy? Czy to rozwiązanie jest bezpieczne (np. Czy nadal będzie używać https)? –
Twój kod działa. Właśnie zaczęło się to dziać dla mnie tylko przez 3G (Telenor, Szwecja). Czy istnieje potencjalny problem z tym, że zawsze jest to możliwe? – apanloco
Czy istnieje problem z włączeniem go zawsze? –