2010-11-28 5 views
3

を発見した私はStartSSL/StartComから次の証明書を持っている:ませサブジェクト代替DNS名がex.ample.comで実行している私のアプリケーションのために

Certificate: 
    Data: 
     Version: 3 (0x2) 
     Serial Number: 163069 (0x27cfd) 
     Signature Algorithm: sha1WithRSAEncryption 
     Issuer: C=IL, O=StartCom Ltd., OU=Secure Digital Certificate Signing, CN=StartCom Class 1 Primary Intermediate Server CA 
     Validity 
      Not Before: Nov 27 21:26:01 2010 GMT 
      Not After : Nov 29 15:32:05 2011 GMT 
     Subject: description=303703-Sv1xMdnmzg6garMt, C=NL, O=Persona Not Validated, OU=StartCom Free Certificate Member, CN=ex.ample.com/[email protected] 
     Subject Public Key Info: 
      Public Key Algorithm: rsaEncryption 
      RSA Public Key: (2048 bit) 
       Modulus (2048 bit): 
        .... 
       Exponent: 65537 (0x10001) 
     X509v3 extensions: 
      X509v3 Basic Constraints: 
       CA:FALSE 
      X509v3 Key Usage: 
       Digital Signature, Key Encipherment, Key Agreement 
      X509v3 Extended Key Usage: 
       TLS Web Server Authentication 
      X509v3 Subject Key Identifier: 
       31:68:B2:7B:A2:7C:79:54:B7:3E:66:FD:12:04:18:FC:FB:9B:34:64 
      X509v3 Authority Key Identifier: 
       keyid:EB:42:34:D0:98:B0:AB:9F:F4:1B:6B:08:F7:CC:64:2E:EF:0E:2C:45 

      X509v3 Subject Alternative Name: 
       DNS:ex.ample.com, DNS:ample.com 
      X509v3 Certificate Policies: 
       Policy: 1.3.6.1.4.1.23223.1.2.2 
        CPS: http://www.startssl.com/policy.pdf 
        CPS: http://www.startssl.com/intermediate.pdf 
        User Notice: 
        Organization: StartCom Ltd. 
        Number: 1 
        Explicit Text: Limited Liability, see section *Legal Limitations* of the StartCom Certification Authority Policy available at http://www.startssl.com/policy.pdf 

      X509v3 CRL Distribution Points: 
       URI:http://www.startssl.com/crt1-crl.crl 
       URI:http://crl.startssl.com/crt1-crl.crl 

      Authority Information Access: 
       OCSP - URI:http://ocsp.startssl.com/sub/class1/server/ca 
       CA Issuers - URI:http://www.startssl.com/certs/sub.class1.server.ca.crt 

      X509v3 Issuer Alternative Name: 
       URI:http://www.startssl.com/ 
    Signature Algorithm: sha1WithRSAEncryption 
     ..... 

私はこの証明書が正しくインストールされています。 Firefoxでアプリにアクセスすると動作します。 私もそれからページを取得するために、JavaのHttpURLConnectionを使用すると、私は次のエラーを取得する:

Caused by: java.security.cert.CertificateException: No subject alternative DNS name matching ex.ample.com found. 
    at sun.security.util.HostnameChecker.matchDNS(HostnameChecker.java:208) 
    at sun.security.util.HostnameChecker.match(HostnameChecker.java:94) 
    at sun.security.ssl.X509TrustManagerImpl.checkIdentity(X509TrustManagerImpl.java:285) 
    at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:271) 
    at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1012) 
    ... 14 more 

これがなぜ起こるか私は理解していません。 ex.ample.comは、証明書のCommon Name(CN)であり、SANにもリストされています。 StarSLLの証明書をトラストストアにインポートしましたので、ここで問題はありません。

+0

URLは何ですか?ちなみに、CNは有効なホスト名を含んでいませんが、サブジェクトの代替名は含みません。 –

+1

URLは単にhttps://ex.ample.com/foo/barです。明らかにそれはサンプルであり、実際のURLではなく、JavaからアクセスするURLは通常のブラウザで正常に動作します。 –

+0

サンプルだと分かります。これらのクラスのJavaソースコードを見ると、実際のURL /証明書にはあなたのサンプルに関するものがかなり忠実ではないようです。または、私が何かを見逃していた可能性があります、HostnameCheckerは複雑なクラスです。 –

答えて

0

答えを探しているのかどうかはわかりません。おそらくそうではありません!

ここでの問題は、証明書のDNSエントリが、アプリケーションで提供しているサーバー/ホスト名と一致しないことです。あなたのコードはどこかでホスト名の確認をしています。そのコードを削除するか、証明書のDNS名に提供するホスト名を変更します。

関連する問題