JSSE編程基本代碼

來源:互聯網
上載者:User

標籤:jsse

 public static void main(String[] args) throws Exception {               //空實現,接受任意服務端的認證。如果用可信公開金鑰庫去構造,採用類同下面的KeyManagerFactory        //的TrustManagerFactory;       TrustManager tm = new X509TrustManager() {        @Override        public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {          //todo                      }        @Override        public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {           //todo          }        @Override        public X509Certificate[] getAcceptedIssuers() {            return null;        }       };              SSLContext sslContext = SSLContext.getInstance("SSL");              //自身的認證需要有密鑰庫,不能像TrustManager那樣去構造       KeyStore ks = KeyStore.getInstance("JKS");       ks.load(new FileInputStream("keystore.jks"),"password".toCharArray());              KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");       kmf.init(ks, "password".toCharArray());              KeyManager km = new MyKeyManager((X509KeyManager)kmf.getKeyManagers()[0]);                     sslContext.init(new KeyManager[]{km}, new TrustManager[]{tm}, new SecureRandom());              SSLSocket ss =  (SSLSocket)sslContext.getSocketFactory().createSocket("localhost",8080);               //監聽handshake完成事件。       ss.addHandshakeCompletedListener(new HandshakeCompletedListener() {         @Override        public void handshakeCompleted(HandshakeCompletedEvent event) {            System.out.println(event);        }       });           }
public class MyKeyManager implements X509KeyManager {    private X509KeyManager delegate;        public MyKeyManager(X509KeyManager delegate){        this.delegate = delegate;    }    @Override    public String[] getClientAliases(String keyType, Principal[] issuers) {        return delegate.getClientAliases(keyType, issuers);    }    @Override    public String chooseClientAlias(String[] keyType, Principal[] issuers, Socket socket) {        return delegate.chooseClientAlias(keyType, issuers, socket);    }    @Override    public String[] getServerAliases(String keyType, Principal[] issuers) {        return delegate.getServerAliases(keyType, issuers);    }    @Override    public String chooseServerAlias(String keyType, Principal[] issuers, Socket socket) {        return delegate.chooseServerAlias(keyType, issuers, socket);    }    @Override    public X509Certificate[] getCertificateChain(String alias) {        return delegate.getCertificateChain(alias);    }    @Override    public PrivateKey getPrivateKey(String alias) {        return delegate.getPrivateKey(alias);    }}


本文出自 “天下無賊” 部落格,請務必保留此出處http://guojuanjun.blog.51cto.com/277646/1955239

JSSE編程基本代碼

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.