如何使用httpclient从android调用https安全rest服务
我已经成功地用http调用了Android中的rest服务 但现在我想在android中调用HTTPS restful服务 我正在使用apache的HttpTime API调用rest服务如何使用httpclient从android调用https安全rest服务,android,rest,https,Android,Rest,Https,我已经成功地用http调用了Android中的rest服务 但现在我想在android中调用HTTPS restful服务 我正在使用apache的HttpTime API调用rest服务 请任何人都可以帮助我调用android中的安全rest服务以下是用于忽略SSL证书错误的示例代码,创建一个名为SimpleSSLSocketFactory的新java类 public class SimpleSSLSocketFactory extends org.apache.http.conn.ssl
请任何人都可以帮助我调用android中的安全rest服务以下是用于忽略SSL证书错误的示例代码,创建一个名为SimpleSSLSocketFactory的新java类
public class SimpleSSLSocketFactory extends org.apache.http.conn.ssl.SSLSocketFactory {
private SSLSocketFactory sslFactory = HttpsURLConnection.getDefaultSSLSocketFactory();
public SimpleSSLSocketFactory(KeyStore truststore) throws NoSuchAlgorithmException, KeyManagementException, KeyStoreException,
UnrecoverableKeyException {
super(null);
try {
SSLContext context = SSLContext.getInstance("TLS");
// Create a trust manager that does not validate certificate chains and simply
// accept all type of certificates
TrustManager[] trustAllCerts = new TrustManager[] { new X509TrustManager() {
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return new java.security.cert.X509Certificate[] {};
}
public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
} };
// Initialize the socket factory
context.init(null, trustAllCerts, new SecureRandom());
sslFactory = context.getSocketFactory();
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public Socket createSocket(Socket socket, String host, int port, boolean autoClose) throws IOException, UnknownHostException {
return sslFactory.createSocket(socket, host, port, autoClose);
}
@Override
public Socket createSocket() throws IOException {
return sslFactory.createSocket();
}
}
并使用以下httpclient而不是默认客户端
// Setup a custom SSL Factory object which simply ignore the certificates
// validation and accept all type of self signed certificates
SSLSocketFactory sslFactory = new SimpleSSLSocketFactory(null);
sslFactory.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
// Enable HTTP parameters
HttpParams paramsSecure = new BasicHttpParams();
HttpProtocolParams.setVersion(paramsSecure, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset(paramsSecure, HTTP.UTF_8);
// Register the HTTP and HTTPS Protocols. For HTTPS, register our custom SSL Factory object.
SchemeRegistry registry = new SchemeRegistry();
registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
registry.register(new Scheme("https", sslFactory, 443));
// Create a new connection manager using the newly created registry and then create a new HTTP client
// using this connection manager
ClientConnectionManager ccm = new ThreadSafeClientConnManager(paramsSecure, registry);
HttpClient httpclient = new DefaultHttpClient(ccm, paramsSecure);
干杯 你有任何问题吗?我想你不应该,如果有,那怎么办?我已经尝试了这个链接,但我不明白如何使用这个SSL与HttpClient来调用我的服务Sourabh thanx,以获得你的答复。。。。。但是现在给出了“500内部服务器错误”html作为回复您是否在本地服务器上运行此服务?