Is it possible to automatically select correct client side certificate?

前端 未结 3 777
时光取名叫无心
时光取名叫无心 2021-01-21 17:22

I have configured an Apache httpd website with SSL client side certificates so that only users who have installed the correct certificate in their web browsers can access the we

相关标签:
3条回答
  • 2021-01-21 17:57

    The SSL (TLS) protocol only allows the server to specify two constraints on the client certificate:

    1. The type of certificate (RSA, DSA, etc.)
    2. The trusted certificate authorities (CAs) that signed the client certificate

    You can use "openssl s_client" to see which CAs your Apache server trusts for client certs. I do not know how to configure Apache to change that list (sorry), but I bet there is a way. So if you can limit the list to (say) your own organization's CA alone, then you will have done all you can to allow a Web browser to select the client cert automatically.

    As Eugene said, whether the browser actually does so is up to the particular browser.

    0 讨论(0)
  • 2021-01-21 17:59

    In addition to what @Nemo and @Eugene said, by default, Apache Httpd will send the list of CAs it gets from its SSLCACertificateFile or SSLCACertificatePath configuration directives.

    However, you can force it to send a different list in certificate_authorities using the SSLCADNRequestFile or SSLCADNRequestPath directives and pointing them to another set of certificates. Only the Subject DN of these certificates is used (and send in the list). If you want to force certain names, you can even self-sign these certificates with whichever name you want. I've tried this (in conjunction with SSLVerifyClient optional_no_ca, and you can get clients to send certificates for CA certificates that the server doesn't actually have. (This isn't necessarily useful, but it works.)

    0 讨论(0)
  • 2021-01-21 18:16

    I'd say that as selection of the certificate is a client-side task, there's no definite way to force the client use this or that certificate from the server side.

    0 讨论(0)
提交回复
热议问题