Seguindo esse tutorial você irá habilitar o uso de conexão segura (https) no seu servidor Apache2 usando o módulo SSL, criando chaves pública e privada e configurando o apache para usá-las.
Esse tutorial está assumindo que você instalou o Ubuntu Feisty Fawn (7.04) versão Server, escolhendo a opção ‘Instalar Servidor LAMP”, apesar que pode ser útil em qualquer caso.
Instalando pacotes adicionais
Você já tem Servidor Linux+Apache+MySQL+PHP com pouco esforço com o Ubuntu e ele resolve a maior parte das demandas. Vamos adicionar ao pacote a possibilidade que seja possível navegar pelo seu site com uma conexão segura, o ‘https’. Para tanto, instale os pacotes adicionais para criar as chaves criptografadas.
sudo aptitude install openssl ssl-cert
Criando chaves pública e privada
Vamos criar uma pasta para guardar as chaves e usar um script para, respondendo algumas perguntas, criar chaves pública e privada que serão usadas pelo Apache2.
sudo mkdir /etc/apache2/ssl sudo make-ssl-cert /usr/share/ssl-cert/ssleay.cnf /etc/apache2/ssl/apache.pem
Configurando o módulo SSL do Apache2
Vamos agora configurar o Apache2 para que além de usar a porta 80 ele use a porta 443, que é a porta padrão do https.
sudo su -c 'echo Listen 443 >> /etc/apache2/ports.conf'
Depois disso, iremos habilitar o módulo ssl do Apache2.
sudo a2enmod ssl
Configurando o site com https
Você pode ter vários sites hospedados pelo mesmo Apache, nós iremos criar um segundo site no seu servidor, que na verdade é o site padrão usando https
sudo cp /etc/apache2/sites-available/default /etc/apache2/sites-available/ssl sudo nano /etc/apache2/sites-available/ssl
Modifique o arquivo para usar a porta 443 e habilite a função SSL usando o certificado que criamos:
NameVirtualHost *:443 <VirtualHost *:443 > ServerAdmin webmaster@localhost SSLEngine On SSLCertificateFile /etc/apache2/ssl/apache.pem DocumentRoot /var/www/
Depois de editar o arquivo, habilite o site
sudo a2ensite ssl
E force o Apache2 a recarregar as configurações
sudo /etc/init.d/apache2 force-reload
Testando
Se não houve nenhuma mensagem de erro quando você forçou a reconfiguração do Apache2 é quase certo que quando você acessar “https://’ip-do-seu-servidor‘” verá seu site, mas a comunicação entre seu navegador e o servidor é criptografada.
————————–
Agradecimentos a http://wiki.ubuntubrasil.org/GleidsonLacerda
——————————————–
Este trecho é meu:
Se por um “acaso”, você receber a mensagem de que a porta SSL não pode ser ativada (0.0.0.0:443), você pode acessar o arquivo
/etc/apache2/ports.conf'
e eliminar a linha (deve ser a última) que indica acesso pela porta 443 (caso a default 80 esteja informada).