Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7635761
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 31, 20262026-05-31T07:30:27+00:00 2026-05-31T07:30:27+00:00

Problem I want to send https request to the site https://10.2.20.20/fido/EzPay/login.php my own server

  • 0

Problem

I want to send https request to the site https://10.2.20.20/fido/EzPay/login.php my own server and get response from it and save it for example in a string. I have found some example codes in internet and try to test them for my problem but they are not helpful. Below I present some parts of codes which I have tested.


Code Example:

I try this code, but I always get same exception “No peer certificate” Why ?

try
{
    HostnameVerifier hostnameVerifier = org.apache.http.conn.ssl.SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER;

    DefaultHttpClient client = new DefaultHttpClient();

    SchemeRegistry registry = new SchemeRegistry();
    SSLSocketFactory socketFactory = SSLSocketFactory.getSocketFactory();
    socketFactory.setHostnameVerifier((X509HostnameVerifier) hostnameVerifier);
    registry.register(new Scheme("https", socketFactory, 443));
    SingleClientConnManager mgr = new SingleClientConnManager(client.getParams(), registry);
    DefaultHttpClient httpClient = new DefaultHttpClient(mgr, client.getParams());

    // Set verifier      
    HttpsURLConnection.setDefaultHostnameVerifier(hostnameVerifier);

    // Example send http request
    final String url = "https://10.2.20.20/fido/EzPay/login.php";
    HttpPost httpPost = new HttpPost(url);
    HttpResponse response = httpClient.execute(httpPost);

    BufferedReader rd = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
    String line = "";
    while ((line = rd.readLine()) != null) {
        Log.i(DownloadImageTask.class.getName(), line);
    }

}
catch(IOException ex)
{
    Log.e(DownloadImageTask.class.getName(), ex.getMessage());
}

Exception.

03-02 16:58:25.234: W/System.err(1868):
javax.net.ssl.SSLPeerUnverifiedException: No peer certificate 03-02
16:58:25.238: W/System.err(1868): at
org.apache.harmony.xnet.provider.jsse.SSLSessionImpl.getPeerCertificates(SSLSessionImpl.java:137)
03-02 16:58:25.238: W/System.err(1868): at
org.apache.http.conn.ssl.AbstractVerifier.verify(AbstractVerifier.java:93)
03-02 16:58:25.238: W/System.err(1868): at
org.apache.http.conn.ssl.SSLSocketFactory.createSocket(SSLSocketFactory.java:381)
03-02 16:58:25.238: W/System.err(1868): at
org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:165)
03-02 16:58:25.250: W/System.err(1868): at
org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
03-02 16:58:25.250: W/System.err(1868): at
org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
03-02 16:58:25.250: W/System.err(1868): at
org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
03-02 16:58:25.250: W/System.err(1868): at
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
03-02 16:58:25.250: W/System.err(1868): at
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
03-02 16:58:25.250: W/System.err(1868): at
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
03-02 16:58:25.250: W/System.err(1868): at
com.https.test.DownloadImageTask.doInBackground(Https_testActivity.java:78)
03-02 16:58:25.250: W/System.err(1868): at
com.https.test.DownloadImageTask.doInBackground(Https_testActivity.java:1)
03-02 16:58:25.250: W/System.err(1868): at
android.os.AsyncTask$2.call(AsyncTask.java:264) 03-02 16:58:25.253:
W/System.err(1868): at
java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
03-02 16:58:25.253: W/System.err(1868): at
java.util.concurrent.FutureTask.run(FutureTask.java:137) 03-02
16:58:25.253: W/System.err(1868): at
android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208) 03-02
16:58:25.257: W/System.err(1868): at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
03-02 16:58:25.257: W/System.err(1868): at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
03-02 16:58:25.257: W/System.err(1868): at
java.lang.Thread.run(Thread.java:856)


Question

What I’m doing wrong and how I can solve this issue. Why I get “No peer certificate” exception ?

Thanks.

Edited


Windows Server settings.

<VirtualHost *:443>
  ServerName 10.2.20.20

 Alias /fido/EzPay/ "d:/fido/EzPay/" 
Alias /fido/EzPay "d:/fido/EzPay/" 

<Directory "d:/fido/EzPay/">
    Options Indexes FollowSymLinks MultiViews
    AllowOverride all
        Order allow,deny
    Allow from all
</Directory>


  # These are the actual SSL directives needed to get it all working!
  SSLEngine on
  SSLCertificateFile C:/wamp/bin/apache/apache2.2.17/conf/ssl/fidoserver.crt
  SSLCertificateKeyFile C:/wamp/bin/apache/apache2.2.17/conf/ssl/fidoserver.pem
</VirtualHost>
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-31T07:30:29+00:00Added an answer on May 31, 2026 at 7:30 am

    Finally I have solved https problem. As I fought the main problem was in server, concretely in certificate.
    Android supports only “BKS” certificate and that’s was the reason that we can’t get response from the
    server. In order to solve this issue I have read more then 30 articles and finally found solution.

    The steps which I done to solve this issue you can see below:

    First thing that I do was generating .bks keystore file from our fidoserver.crt certificate, in order to do that I have read this article and do following:

    1. Open cmd
    2. Go to JDK folder “cd X:\Programs\Java\Jdk6\bin”
    3. Call following command:

    keytool -import -alias tomcat -file X://KeyStore/fidoserver.crt
    -keypass password – keystore X://KeyStore/keystore.bks -storetype BKS -storepass 222222 -providerClass
    org.bouncycastle.jce.provider.BouncyCastleProvider -providerpath
    X://KeyStore/bcprov-jdk16-146.jar

    Before running this command I have download Bouncy Castle .jar file and put it in the folder with certificates. After doing this all steps I get keystore.bks file which is the right certificate file for Android application. I put this file in Androids mnc/sdcard folder. In java code I have write following code to read that keystore.bbk file

    KeyStore trustStore  = KeyStore.getInstance( "BKS" /*KeyStore.getDefaultType()*/ );
    FileInputStream instream = new FileInputStream(new File("/mnt/sdcard/keystore.bks"));
    try {
        trustStore.load(instream, "222222".toCharArray());
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    } catch (CertificateException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    } finally {
        try { instream.close(); } catch (Exception ignore) {}
    }
    
    // Create socket factory with given keystore.
    SSLSocketFactory socketFactory = new SSLSocketFactory(trustStore);
    
    SSLSocketFactory socketFactory = new SSLSocketFactory(trustStore);
    Scheme sch = new Scheme("https", socketFactory, 443);
    httpclient.getConnectionManager().getSchemeRegistry().register(sch);
    
    HttpGet httpget = new HttpGet("https://10.2.20.20/fido/EzPay/login.php");
    
    System.out.println("executing request " + httpget.getRequestLine());
    
    HttpResponse response = httpclient.execute(httpget);
    HttpEntity entity = response.getEntity();
    
    System.out.println("----------------------------------------");
    System.out.println(response.getStatusLine());
    if (entity != null) {
        System.out.println("Response content length:  " + entity.getContentLength());
    }
                
    // Print html.
    BufferedReader in = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
    String line = "";
    while ((line = in.readLine()) != null) {
         System.out.println(line);
    }
    in.close();
    

    This all allow m to load our certificate with given password 222222 (password we give when create a keystore with keytool).

    After this all my test application start to work correctly. Now I can send request to https and get response from it. I have tested
    application with FIDO server, everything works great! I think on Monday I will make some changes in EzPay application and it
    will start working with https connections.

    References

    • Using TLS with Apache Tomcat and Android
    • SSL Verification for Android Applications
    • KeyStore
    • Android: Trusting SSL certificates
    • Bouncy Castle
    • Android/Java — How to Create HTTPS Connection?
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I want to make am HTTP GET request from my J2ME application using HttpConnection
I want to send a couple of values to a web server from my
I have data that I want to send through an ajax GET request in
my client have 2 server and from first server then want to send a
I need to use a GET request to send JSON to my server via
Can any one solve my problem. I want to send a http request in
I want to get the IP from the current user and send it along
Problem: I want to list n number of games from each genre (order not
This is what I want to do: I want to send an HTTP request
I want to fetch a web page from a ASP.NET site that is only

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.