2013-04-02 57 views
0

我每天都需要执行例程,连接到远程地址,使用智能卡进行身份验证,然后在此远程地址检查我的用户名的任何新信息。Java智能卡HttpClient身份验证

我想做这个例程自动,创建一个Java应用程序,将连接到该地址,用智能卡进行身份验证,然后检查是否有任何新的信息。

我试过了,但没有成功用智能卡设置HttpClient环境,我将卡插在我的机器上并设置Cronjob运行,它返回了没有插入卡的警告。

的代码如下:

HttpClient httpClient = new DefaultHttpClient(); 
      // Secure Protocol implementation. 
      SSLContext ctx = SSLContext.getInstance("SSL"); 
      // Implementation of a trust manager for X509 certificates 
      X509TrustManager tm = new X509TrustManager() { 

       public java.security.cert.X509Certificate[] getAcceptedIssuers() { 
        return null; 
       } 

       public void checkClientTrusted(java.security.cert.X509Certificate[] arg0, String arg1) throws java.security.cert.CertificateException { 
        // TODO Auto-generated method stub 
       } 

       @Override 
       public void checkServerTrusted(
         java.security.cert.X509Certificate[] arg0, String arg1) 
         throws java.security.cert.CertificateException { 
        // TODO Auto-generated method stub 

       } 
      }; 
      ctx.init(null, new TrustManager[] { tm }, null); 
      SSLSocketFactory ssf = new SSLSocketFactory(ctx); 

      ClientConnectionManager ccm = httpClient.getConnectionManager(); 
      // register https protocol in httpclient's scheme registry 
      SchemeRegistry sr = ccm.getSchemeRegistry(); 
      sr.register(new Scheme("https", 443, ssf)); 

      HttpGet httpget = new HttpGet("http://remoteserver.com/login.seam"); 
      HttpParams params = httpclient.getParams(); 

      params.setParameter("param1", "paramValue1"); 

      httpget.setParams(params); 
      System.out.println("REQUEST:" + httpget.getURI()); 
      ResponseHandler responseHandler = new BasicResponseHandler(); 
      String responseBody; 

      responseBody = httpclient.execute(httpget, responseHandler); 

      System.out.println(responseBody); 

是否有任何与它的帮助吗?我搜索了很多,但我无法连接使用智能卡...

在此先感谢和抱歉我的英语不好。

回答

1

我们没有看到关于智能卡读卡器的代码。 第一次你必须从你的智能卡获取信息。 尝试查看如何使用smartcardio库。 然后将所有信息从您的应用程序发送到网站。

我认为它可以帮助你,如果我明白你的问题。