Nesse artigo iremos explicar o conceito básico de certificação digital, mostraremos como se gera uma requisição de certificado, chaves privadas e públicas e configurações https do Apache2 para que nosso site possua certificado digital.
Uma "Requisição de Certificado" se faz necessário quando queremos obter um "Certificado Digital", pois nele estaremos informando dados que serão enviados para um CA. Pode ser ela uma CA interna (não registrada pela ICP-Brasil), ou uma CA autorizada (pela ICP-Brasil), no exemplo, SERPRO.
Iremos aqui atribuir uma URL a uma máquina, a um proprietário e aos dados do mesmo. Isso servirá para que a CA, na hora de gerar o certificado, coloque essas informações, que serão vistas por todo e qualquer usuário que acessar o site em questão.
Uma "Requisição de Certificado" é um arquivo que conterá informações de nossa "chave privada" (informações da máquina onde configuraremos nosso certificado) e também informações adicionais que serão acrescidas na hora de criar o mesmo, assim como já dito anteriormente.
Vale uma ressalva para "chave pública", ela é a responsável por conseguir decriptografar as informações contidas em nossa "chave privada", que está em nosso servidor. Porém, em nosso exemplo não mandaremos apenas a "chave pública" via browser, e sim um Certificado Digital autêntico.
Usamos somente a chave pública, para o caso de estarmos usando uma CA privada, para uma rede interna por exemplo.
Com isso, se faz claro, que quando geramos uma "Requisição de Certificado", além das informações obtidas da chave privada e das informadas na hora de sua criação, ela automaticamente cria a chave pública, que voltará também juntamente com o CERTIFICADO que foi emitido pela CA, possibilitando assim que o cliente, em seu browser, consiga interpretar nosso certificado.
Gerando a "Requisição do Certificado":
1º Passo - Dentro do diretório onde criamos nossa "chave privada" iremos executar o comando abaixo. Criaremos uma "requisição de certificado", que lhe pedirá algumas informações como pode ser visto abaixo:
No comando acima, estamos gerando nosso certificado ("requisicao_certificado") a partir de nossa chave privada "chave_privada.key".
Devemos ter um resultado similar ao mostrado a seguir:
# openssl req -new -nodes -key chave_privada.key -out requisicao_certificado
Enter pass phrase for chave_privada.key:
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:BR
State or Province Name (full name) [Some-State]:Distrito Federal
Locality Name (eg, city) []:Brasilia
Organization Name (eg, company) [Internet Widgits Pty Ltd]:NOME DA EMPRESA OU RESPONSÁVEL PELO SITE
Organizational Unit Name (eg, section) []:ORGANIZAÇÃO, CASO HAJA
Common Name (eg, YOUR name) []:URL DO SITE, ou nome do servidor, ex: www.meusite.com, nomedomeuservidor
Email Address []:suporte@bruno.com.br
Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:SENHA LEMBRETE PARA SENHA(OPCIONAL)
An optional company name []:OPÇÃO NOME DA EMPRESA OU SIGLA
Como podemos ver acima, entramos com vários dados e os mesmos gerarão nossa requisição.
O conteúdo do arquivo "requisicao_certificado"(vide abaixo) é o que devemos mandar para nossa CA (SERPRO no caso), para que ele gere nosso certificado.
O arquivo gerado (requisicao_certificado)terá como seu conteúdo similar ao mostrado abaixo:
Esse procedimento demorará alguns dias, pois envolve pagamento e processo de registro, porém, não mais que 10 dias.
No site do SERPRO, onde podemos comprar, registrar e baixar nosso certificado, iremos colocar nossa requisição de certificado. Esse processo é muito simples e particular.
Caso você escolha outra CA, isso não terá problema, pois o que você precisa ter em mãos independentemente da CA escolhida é a sua "Requisição de Certificado", a qual você acaba de criar.
Inclusive se você for usar uma CA local (sua própria máquina), usando o Openssl você pode gerar um certificado, porém, não será um certificado válido e reconhecido, assim como já foi explicado.
[5] Comentário enviado por caiogustavo15 em 04/04/2008 - 20:18h
Muito interessante esse seu artigo. Há algum tempo venho procurando algo assim, mais ainda não tinha achado. Mais como sou "iniciante" ainda tenho algumas dúvidas. No meu caso quero fazer essa implementação pois no prédio onde moro nós dividimos uma rede wirelless, mais as vezes aparece algum conhecido que quer usar a rede e temos que ficar colocando senha, liberando o MAC no ap.. essas coisas, e por isso gostaria de usar esse método para "liberar" o acesso de pessoas na rede. Você teriam mais algum artigo que pudesse me ajudar?? Alguma outra leitura pra me indicar ?? Obrigado!
[10] Comentário enviado por leows em 23/12/2008 - 11:03h
Para não pedir senha caso crie um certificado seguro, basta adicionar esse script em /etc/init.d
instale o interpretador expect com o comando:
apt-get install expect
ATENÇÃO: altere o valor <password> do conteúdo do script abaixo para a senha que vc criou na sua phrase do certificado.
# crie um arquivo chamado webserver em /etc/init.d
vi /etc/init.d/webserver
#!/bin/bash
# /etc/init.d/webserver
#
set -e
set -u
test -x /etc/init.d/apache2 || exit 0
. /lib/lsb/init-functions
case "${1:-''}" in
'start')
/usr/bin/expect -c '
set force_conservative 0 ;# set to 1 to force conservative mode even if
if {$force_conservative} {
set send_slow {1 .001}
proc send {ignore arg} {
sleep .1
exp_send -s -- $arg
}
}
set timeout 2
puts "\n"
spawn /etc/init.d/apache2 start
expect "phrase:"
send "<password>\r"
expect "OK"
puts "\r"
exit
'
;;
[11] Comentário enviado por thiagoborn em 06/06/2012 - 22:59h
Você saberia como configurar o apache 2.2 para que ele peça o certificado do cliente para fechar conexão?
Client Faz requisição -> Apache
Apache pede certificado de cliente. E por aí vai