sto usando HttpClient per richieste HTTPS, che ha funzionato benissimo fino ad ora. Dopo l'aggiornamento a ICS, alcuni utenti segnalano problemi di connessione su connessioni 3G.Android: Scheme 'http' non registrata su ICS 4.0.4 w/procura
EDIT: La maggior parte di loro sembrano essere utilizzando un proxy, e posso riprodurre questo localmente con un T-Mobile SIM usando il loro proxy.
I registri hanno questa analisi dello stack:
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)
L'end point è solo HTTPS, quindi non abbiamo un endpoint HTTP nel nostro SchemeRegistry apposta. Non c'è nessun luogo (AFAIK) in cui reindirizziamo a HTTP.
Ecco il codice che imposta il HttpClient per il 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: Condividiamo questo caso HttpClient tra più thread.
Che cos'è BYPASS_PROXY? Perché non possiamo usare sempre questo route planner? Questa soluzione è sicura (ad esempio, continuerà a utilizzare https)? –
Il codice è il trucco. E 'appena iniziato all'improvviso per me solo su 3G (Telenor, Svezia). C'è qualche potenziale problema con questo sempre acceso? – apanloco
Quindi c'è un problema nell'avere sempre acceso? –