I have problem with some device, and the error said that SSL problem. When I check my website it has no problem there. Here my code to get A data from database
public class HttpServicesClass {
public int responseCode;
public String message;
public String response;
public ArrayList<NameValuePair> ArrayListParams;
public ArrayList <NameValuePair> headers;
public String UrlHolder;
public String getResponse()
{
return response;
}
public String getErrorMessage()
{
return message;
}
public int getResponseCode()
{
return responseCode;
}
public HttpServicesClass(String url)
{
HttpServicesClass.this.UrlHolder = url;
ArrayListParams = new ArrayList<NameValuePair>();
headers = new ArrayList<NameValuePair>();
}
public void AddParam(String name, String value)
{
ArrayListParams.add(new BasicNameValuePair(name, value));
}
public void AddHeader(String name, String value)
{
headers.add(new BasicNameValuePair(name, value));
}
public void ExecuteGetRequest() throws Exception
{
String MixParams = "";
if(!ArrayListParams.isEmpty())
{
MixParams += "?";
for(NameValuePair p : ArrayListParams)
{
String paramString = p.getName() + "=" + URLEncoder.encode(p.getValue(),"UTF-8");
if(MixParams.length() > 1)
{
MixParams += "&" + paramString;
}
else
{
MixParams += paramString;
}
}
}
HttpGet httpGet = new HttpGet(UrlHolder + MixParams);
for(NameValuePair h : headers)
{
httpGet.addHeader(h.getName(), h.getValue());
}
executeRequest(httpGet, UrlHolder);
}
public void ExecutePostRequest() throws Exception
{
HttpPost httpPost = new HttpPost(UrlHolder);
for(NameValuePair h : headers)
{
httpPost.addHeader(h.getName(), h.getValue());
}
if(!ArrayListParams.isEmpty())
{
httpPost.setEntity(new UrlEncodedFormEntity(ArrayListParams, HTTP.UTF_8));
}
executeRequest(httpPost, UrlHolder);
}
private void executeRequest(HttpUriRequest request, String url)
{
HostnameVerifier hostnameVerifier = org.apache.http.conn.ssl.SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER;
HttpParams httpParameters = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(httpParameters, 10000);
HttpConnectionParams.setSoTimeout(httpParameters, 10000);
HttpClient httpClient = new DefaultHttpClient(httpParameters);
SchemeRegistry registry = new SchemeRegistry();
SSLSocketFactory socketFactory = SSLSocketFactory.getSocketFactory();
socketFactory.setHostnameVerifier((X509HostnameVerifier) hostnameVerifier);
registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
registry.register(new Scheme("https", socketFactory, 443));
SingleClientConnManager mgr = new SingleClientConnManager(httpParameters, registry);
HttpsURLConnection.setDefaultHostnameVerifier(hostnameVerifier);
new DefaultHttpClient(mgr, httpParameters);
HttpResponse httpResponse;
try
{
httpResponse = httpClient.execute(request);
responseCode = httpResponse.getStatusLine().getStatusCode();
message = httpResponse.getStatusLine().getReasonPhrase();
HttpEntity entity = httpResponse.getEntity();
if (entity != null)
{
InputStream inputStream = entity.getContent();
response = convertStreamToString(inputStream);
inputStream.close();
}
}
catch (ClientProtocolException e)
{
httpClient.getConnectionManager().shutdown();
e.printStackTrace();
}
catch (IOException e)
{
httpClient.getConnectionManager().shutdown();
e.printStackTrace();
}
}
private String convertStreamToString(InputStream is)
{
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is));
StringBuilder stringBuilder = new StringBuilder();
String line = null;
try
{
while ((line = bufferedReader.readLine()) != null)
{
stringBuilder.append(line + "\n");
}
}
catch (IOException e)
{
e.printStackTrace();
}
finally
{
try
{
is.close();
}
catch (IOException e)
{
e.printStackTrace();
}
}
return stringBuilder.toString();
}
}
it's give me error when try to show the database data
W/System.err: javax.net.ssl.SSLPeerUnverifiedException: No peer certificate
Many reference I try but still give me null for this problem Safely fixing: javax.net.ssl.SSLPeerUnverifiedException: No peer certificate
error javax.net.ssl.SSLPeerUnverifiedException: No peer certificate and SSLNullSession.java:104
Anyone can help me to fix this one please
EDIT
Full error log
02-10 07:52:36.565 2621-3000/com.network.poeja.checkops W/System.err: javax.net.ssl.SSLPeerUnverifiedException: No peer certificate 02-10 07:52:36.665 2621-3000/com.network.poeja.checkops W/System.err: at com.android.org.conscrypt.SSLSessionImpl.getPeerCertificates(SSLSessionImpl.java:146) 02-10 07:52:36.665 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.conn.ssl.AbstractVerifier.verify(AbstractVerifier.java:93) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.conn.ssl.SSLSocketFactory.createSocket(SSLSocketFactory.java:388) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:165) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 02-10 07:52:36.675 2621-3000/com.network.poeja.checkops W/System.err: at com.network.poeja.checkops.HttpServicesClass.executeRequest(HttpServicesClass.java:152) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at com.network.poeja.checkops.HttpServicesClass.ExecutePostRequest(HttpServicesClass.java:128) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at com.network.poeja.checkops.SecondFragment$GetHttpResponse.doInBackground(SecondFragment.java:101) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at com.network.poeja.checkops.SecondFragment$GetHttpResponse.doInBackground(SecondFragment.java:78) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at android.os.AsyncTask$2.call(AsyncTask.java:288) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at java.util.concurrent.FutureTask.run(FutureTask.java:237) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 02-10 07:52:36.685 2621-3000/com.network.poeja.checkops W/System.err: at java.lang.Thread.run(Thread.java:841) 02-10 07:52:36.745 2621-3000/com.network.poeja.checkops W/System.err: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare() 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.os.Handler.(Handler.java:200) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.os.Handler.(Handler.java:114) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.widget.Toast$TN.(Toast.java:327) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.widget.Toast.(Toast.java:92) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.widget.Toast.makeText(Toast.java:241) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at com.network.poeja.checkops.SecondFragment$GetHttpResponse.doInBackground(SecondFragment.java:132) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at com.network.poeja.checkops.SecondFragment$GetHttpResponse.doInBackground(SecondFragment.java:78) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.os.AsyncTask$2.call(AsyncTask.java:288) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at java.util.concurrent.FutureTask.run(FutureTask.java:237) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 02-10 07:52:36.785 2621-3000/com.network.poeja.checkops W/System.err: at java.lang.Thread.run(Thread.java:841)