AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / server / Perguntas / 1081716
Accepted
Amandasaurus
Amandasaurus
Asked: 2021-10-27 01:58:08 +0800 CST2021-10-27 01:58:08 +0800 CST 2021-10-27 01:58:08 +0800 CST

Registre o certificado SSL que o Apache está usando para cada conexão SSL, para registro e depuração aprimorados

  • 772

Eu tenho um servidor web apache, com certificados mod_ssl e SSL da letsencrypt. certbotrelatórios estão bem e não expiram. Alguns diferentes (dos meus muitos usuários) relatam que obtêm certificados SSL inválidos/expirados do servidor (e eu vi a saída wgetdeles para provar isso).

Para depurar isso, quero registrar muitos detalhes de cada conexão SSL. Eu gostaria de registrar, para cada conexão SSL, o IP remoto e detalhes sobre a conexão SSL (por exemplo, protocolo), o valor SNI (identificação do nome do servidor) fornecido pelo cliente e, em seguida, qual certificado/cadeia/chave SSL no servidor foi usado . Eu quero

Com ErrorLog ssl:traceN(para vários N) posso obter alguns desses detalhes. Mas não consigo ver qual certificado SSL o servidor está usando para cada conexão. Como posso fazer isso?

logging ssl apache-2.4 lets-encrypt
  • 2 2 respostas
  • 314 Views

2 respostas

  • Voted
  1. Nikita Kipriyanov
    2021-10-27T02:36:30+08:002021-10-27T02:36:30+08:00

    O Apache HTTPD mod_ssldefine várias variáveis ​​de ambiente, algumas das quais podem ser usadas para identificar o certificado do servidor. Por exemplo, existem SSL_SERVER_CERT(um certificado completo codificado em PEM), SSL_SERVER_S_DN(um DN do assunto), SSL_SERVER_M_SERIAL(um número de série do certificado).

    Você pode usá-los na configuração de log:

    CustomLog "logs/ssl_request_log" "... %{SSL_SERVER_S_DN}x ..."
    

    Leia o manual do mod_ssl para obter detalhes.

    • 1
  2. Best Answer
    Lacek
    2021-10-27T02:55:39+08:002021-10-27T02:55:39+08:00

    mod_sslexporta um monte de variáveis ​​de ambiente ( veja a lista aqui ), que podem ser usadas para registrar informações sobre o certificado, por exemplo, em uma LogFormatdiretiva como esta:

    LogFormat "cert_CN='%{SSL_SERVER_S_DN_CN}e', cert_expires='%{SSL_SERVER_V_END}e', vhost='%{Host}i', client='%h'" ssl_combined
    

    No entanto, antes de iniciar o log, verifique este artigo sobre como expirar o certificado DST Root CA X3. É aquele que assinou a CA raiz do Let's Encrypt, e expirou em setembro. No entanto, a CA raiz do Let's Encrypt é aceita como uma CA confiável em praticamente todos os sistemas. Para isso, a expiração não é um problema, e os certificados emitidos continuam funcionando, exceto para sistemas mais antigos usando opensslversão < 1.1.0, que não interrompe a validação quando uma CA confiável é encontrada, mas insiste em verificar toda a cadeia (e falha).

    Se o sistema em questão tiver um openssl, você não pode fazer nada sobre o problema no lado do servidor, openssldevendo ser atualizado no cliente. Se isso não for uma opção, colocar na lista negra o certificado expirado ajuda.

    • 1

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve