目前分類:Java (2)

瀏覽方式: 標題列表 簡短摘要

最近又回頭寫Java的程式,遇到的問題是要去呼叫https secure url,結果一直有Exception產生。

Exception:
javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: No trusted certificate found

網路上的解法不少。但是我試了好幾個還是覺得
這篇作者的解法最容易,也較容易理解。

另外這篇也不錯。

给有可能遇到跟我一樣問題的人參考囉!順便我自己也可以把這樣的問題記錄起來,方便自己以後找問題。




我把作者個code整理如下:

package com.xxx.xxx.util;

import java.security.KeyManagementException;

import java.security.NoSuchAlgorithmException;

import java.security.SecureRandom;

import java.security.Security;

import java.security.cert.CertificateException;

import java.security.cert.X509Certificate;

import javax.net.ssl.SSLContext;

import javax.net.ssl.TrustManager;

import javax.net.ssl.X509TrustManager;

import com.sun.net.ssl.HostnameVerifier;

import com.sun.net.ssl.HttpsURLConnection;

public class SSlTrustManagerTool {

 private SSlTrustManagerTool() {

 }

private static org.apache.log4j.Category logger = org.apache.log4j.Category.getInstance(SSlTrustManagerTool.class);

public static void trustHttpsCertificates() throws NoSuchAlgorithmException, KeyManagementException {   

  Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());  

  // Create a trust manager that does not validate certificate chains:   

  TrustManager[] trustAllCerts = new TrustManager[] { new X509TrustManager() {

        public X509Certificate[] getAcceptedIssuers() {       

           logger.info("getAcceptedIssuers");       

          return null;     

        }     

        public void checkServerTrusted(X509Certificate[] certs,String authType) throws CertificateException {      

        logger.info("checkServerTrusted");       

        return;     

       }     

      public void checkClientTrusted(X509Certificate[] certs,String authType) throws CertificateException {       

        logger.info("checkClientTrusted");      

        return;     

      }   

   } // X509TrustManager   

   };// TrustManager[]   

   // Install the all-trusting trust manager:

    SSLContext sc = SSLContext.getInstance("SSL");   

    sc.init(null, trustAllCerts, new SecureRandom());   

    HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());   

    HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {    

      public boolean verify(String hostname, String session) {       

        logger.info(hostname + " " +  session + " is accepted!");      

        return true;      }  

    }

    );

    }

}



另外使用的方式如下:

URL url=new

URL(
https://www.xxx.xxx
);

com.xxx.xxx.util.SSlTrustManagerTool.trustHttpsCertificates();

//parse output data

String res=new String();

StringBuffer StrBuffer = new StringBuffer();

BufferedReader oIn = new BufferedReader(new InputStreamReader(url.openStream()));

這樣就可以達成Connect to https by Java 囉!!

pcshu 發表在 痞客邦 留言(0) 人氣()

很久之前將Tomcat當作Web Server時,遇到的效能問題、及處理方式。在這個園地提供給需要的人參考囉!!


Linux系統要自動在開機時將Tomcat啟動的方式


 vi /etc/rc.d/rc.local   加入

/opt/Jakarta-tomcat-4.1.29/bin/startup.sh


效能調校


修改tomcat/conf/server.xml

放大connection 數目至 500




port=”80” minProcessors=”5” maxProcessors=”500”

               enableLookups=”true” redirectPort=”443”

               acceptCount=”100” debug=”0” connectionTimeout=”20000”

               useURIValidationHack=”false” disableUploadTimeout=”true” />


建議放大Java的可用記憶體配置

在 /opt/Jakarta-tomcat-4.1.29/bin/startup.sh 加入以下命令將可用記憶體配置放大至768MB(1G的記憶體)

export JAVA_OPTS=-Xmx768m  

重新啟動tomcat

pcshu 發表在 痞客邦 留言(0) 人氣()