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 / 714160
Accepted
Drifter104
Drifter104
Asked: 2015-08-15 00:48:13 +0800 CST2015-08-15 00:48:13 +0800 CST 2015-08-15 00:48:13 +0800 CST

Autenticação SSL do cliente Nginx

  • 772

Eu tenho o Nginx rodando puramente como um proxy para vários servidores web. Um de nossos clientes nos pediu para usar certificados de cliente e nos forneceu 3 certificados para 3 máquinas diferentes que se conectarão a um serviço da Web em execução em um dos servidores proxy.

Nunca tendo feito isso antes, encontrei as configurações nginx relevantes e criei uma configuração do site (parte relevante abaixo)

      server {
        listen                  443 ssl; 
        server_name             service.domain.com;
        ssl_certificate         /etc/nginx/ssl/wildcard/server.crt; 
        ssl_certificate_key     /etc/nginx/ssl/wildcard/server.key; 
        ssl_client_certificate  /etc/nginx/ssl/client.certificates/client_package.cer;
        ssl_verify_client on;

Eu concatenei os 3 certificados de cliente mais um certificado criado por um desenvolvedor (este foi autoassinado) que precisava acessar o site durante o desenvolvimento no único arquivo mencionado acima.

O cliente já tentou acessar o site, mas não consegue. Como teste da configuração, removi o certificado do desenvolvedor do arquivo de certificado concatenado e confirmei que ele não conseguiu acessar o site. Depois que adicionei seu certificado de volta ao arquivo concatenado, ele (desenvolvedor) conseguiu acessar o site corretamente novamente.

Ativei o acesso de nível de depuração no log de erros e, quando o cliente tentou se conectar, recebi o seguinte erro.

2015/08/13 11:57:41 [info] 27601#0: *1963 o cliente não enviou nenhum certificado SSL necessário durante o processamento do SPDY, cliente: 1x.xx.xx.xx, servidor: service.domain.com, solicitação: " GET /test.cfm HTTP/1.1", host: "service.domain.com"

Como você pode ver na configuração acima, não tenho o SPDY ativado (mas tenho em outros sites) e o cliente me garante que está enviando os certificados do cliente. Como esta é a primeira vez que faço isso, quero ter certeza de que, antes de voltar e dizer que meus logs dizem que você não está enviando um certificado de cliente, tenho tudo correto neste final.

Com relação aos certificados que me foram enviados: Todos os 3 são assinados pela mesma autoridade de certificação pública. No entanto, não tenho toda a cadeia no arquivo concatenado. Os guias que encontrei on-line mencionam ter o root ca também, mas todos falam sobre autoassinado, o que nenhum deles é. Portanto, não tenho certeza se isso se aplica.

Para esclarecer, também não estou tentando passar o certificado do cliente para o servidor proxy.

versão nginx: nginx/1.8.0
versão openssl: OpenSSL 1.0.1k 8 de janeiro de 2015

Se houver mais alguma informação necessária, por favor me avise

nginx
  • 3 3 respostas
  • 17460 Views

3 respostas

  • Voted
  1. Best Answer
    dtoubelis
    2015-08-19T20:19:07+08:002015-08-19T20:19:07+08:00

    Sua configuração está realmente correta. No entanto, certifique-se de NÃO colocar certificados de cliente reais em client_package.cerarquivo. Este arquivo deve conter apenas certificados de CA confiáveis; na verdade, ele deve conter a(s) cadeia(s) completa(s). Você deve solicitar todos os certificados raiz e intermediários de seu cliente, caso eles não os tenham fornecido.

    Também existem algumas dicas relacionadas à configuração do servidor padrão. Por favor , leia isto e certifique-se de que não o afeta.

    • 2
  2. mvorisek
    2015-08-17T12:08:25+08:002015-08-17T12:08:25+08:00

    Use ssl_trusted_certificatediretiva em vez de ssl_client_certificate. Consulte os documentos http://nginx.org/en/docs/http/ngx_http_ssl_module.html#ssl_trusted_certificate .

    De qualquer forma, eu recomendaria assinar todos os certificados de cliente com ONE ROOT CA e verificar se o certificado do cliente está assinado com essa CA.

    Se resolveu o seu problema, aceite-o como resposta.

    • 1
  3. x86fantini
    2015-08-17T13:10:55+08:002015-08-17T13:10:55+08:00

    Os certificados SSL são curinga ou domínio único? Talvez o desenvolvedor esteja tentando acessar o URL do site, por exemplo, test.myapp.com, mas o certificado é emitido apenas para myapp.com ou www.myapp.com

    • -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