Estoy usando HttpClient para solicitudes HTTPS, lo que ha funcionado bien hasta ahora. Después de actualizar a ICS, algunos usuarios informan que tienen problemas para conectarse en conexiones 3G.Android: Esquema 'http' no registrado en ICS 4.0.4 w/proxy
EDITAR: La mayoría de ellos parece estar utilizando un proxy, y puedo reproducirlo localmente con una tarjeta SIM de T-Mobile utilizando su proxy.
Los registros tienen esta seguimiento de la pila:
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)
Nuestro punto final es HTTPS, por lo que no se registra un extremo HTTP en nuestro SchemeRegistry a propósito. No hay ningún lugar (AFAIK) donde redirigamos a HTTP.
Aquí está el código que configura el HttpClient para el cliente 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;
Nota: Compartimos este caso HttpClient entre varios subprocesos.
¿Qué es BYPASS_PROXY? ¿Por qué no podemos usar siempre este planificador de rutas? ¿Es segura esta solución (por ejemplo, todavía usará https)? –
Tu código es el truco. De repente, comenzó a sucederme solo a través de 3G (Telenor, Suecia). ¿Hay algún problema potencial con tener esto siempre encendido? – apanloco
Entonces, ¿hay algún problema con tenerlo siempre activado? –