Java Embedded Machine 経由で安全な http に接続しようとしています。
ポート 8090 で自己署名の Apache サーバーを実行しています。Web ブラウザーを使用して移動するhttps://myserver:8090
と、自己署名証明書の警告が表示され、正常に読み込まれます。
私はこのコードを持っています
URL dstUrl = new URL("https://myserver:8090")
URLConnection result = dstUrl.openConnection();
System.out.println("Protocol: "+dstUrl.getProtocol()+", is HTTPS:"+(result instanceof HttpsURLConnection));
// Echo: Protocol HTTPS is HTTPS:false
if (result instanceof HttpsURLConnection) {//will not reach
try {
HttpsURLConnection conn = (HttpsURLConnection) result;
conn.setSSLSocketFactory(sslContext.getSocketFactory());
conn.setHostnameVerifier(defaultHostVerifier);
} catch (Exception e) {
//sout will not ignate
}
}
return (HttpURLConnection) result;
このコードは正常に機能するはずですが、openConecction() は常に HttpUrlConnection を返し、HttpsUrlConnection を返しません。プロトコルが https であることがわかっている場合、強制的に HttpsUrlConnection を開くことができる可能性はありますか?
編集:
私の輸入品:
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URI;
import java.net.URL;
import java.net.URLConnection;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
編集2:
発行者のサイトでURLStreamHandlerFactory
、マシンの起動時に適用される必要があることがわかったので、https プロトコルは非推奨によって返されますcom.sun.net.ssl.internal.www.protocol.https.Handler
これで、javax による HttpsUrlConnection が返されないことがわかりましたが、com.sun.net.ssl.HttpsUrlConnection
とにかくありがとう