El archivo de certificado SSL es un candado.
El archivo de clave de certificado SSL es su clave.
Almacenar los dos juntos es el equivalente a pegar la llave en la cerradura de la puerta principal.
Si un atacante compromete el archivo único, tiene todo lo que necesita para hacerse pasar por su sitio web (el certificado y la clave privada).
Esto es especialmente cierto si no tiene una frase de contraseña en su clave SSL (muchos servidores web no la tienen, para permitir que se inicien automáticamente en caso de bloqueo).
De lo que estás defendiendo al separar los archivos es un error de Apache que hace que descargue el contenido del SSLCertificateFile
(algo que debería estar disponible públicamente) a un cliente web.
(Que yo sepa, no existe tal error, o ha existido alguna vez, pero Apache es un software grande y complejo. Es completamente posible).
Si Apache volca este archivo y todo lo que contiene es el Certificado SSL (el bloqueo), no hay problema: de todos modos, todos obtienen una copia de ese certificado cuando hacen una solicitud SSL al servidor.
Si el archivo también contiene la clave, ha perdido toda posibilidad de seguridad: todo su modelo de cifrado se ve comprometido y debe cambiar las claves.
Las versiones anteriores de OpenSSL requerían dos archivos separados (público y privado). Las versiones anteriores de otros motores de cifrado requerían un único archivo (ambos en el mismo archivo). En el "espíritu" de compatibilidad (también conocido como "El administrador se queja de la inconsistencia y tiene que mantener dos conjuntos de certificados), la mayoría ahora admite ambos.
No se recomienda almacenar ambos certificados (también el llavero) en un solo archivo, ya que los diferentes certificados tienen diferentes ámbitos. Es más un problema de coherencia que técnico, donde el certificado público debe tener permisos de archivo legibles públicamente, y viceversa para el privado. No hay peligro en mantener su certificado público bajo llave en sus sistemas, es simplemente inconsistente con su propósito.
fuente