{"id":15,"date":"2008-06-27T02:40:12","date_gmt":"2008-06-27T02:40:12","guid":{"rendered":"http:\/\/www.apmuga.com\/wordpress\/?p=15"},"modified":"2015-06-13T09:41:57","modified_gmt":"2015-06-13T09:41:57","slug":"configuracao-de-um-servidor-apache-com-ssl-no-windows-2000xp","status":"publish","type":"post","link":"https:\/\/www.apmuga.com\/wordpress\/configuracao-de-um-servidor-apache-com-ssl-no-windows-2000xp\/","title":{"rendered":"Configura\u00e7\u00e3o de um servidor Apache com SSL no Windows 2000\/XP"},"content":{"rendered":"<p><span><\/span><\/p>\n<p><span><span><\/span><\/span><span><span><\/span><\/span><span><span><\/span><\/span><span><span><\/p>\n<h3>\n<table border=\"1\" width=\"100%\">\n<tr bgColor=\"#eeeeee\">\n<td>\n<table border=\"0\" width=\"100%\">\n<tr>\n<td align=\"left\"><span class=\"subtitulo\">Configura\u00e7\u00e3o do servidor Apache com SSL no sistema operativo Windows 2000\/XP<\/span><\/td>\n<td align=\"right\"><a href=\"\/docs\/Apache_SSL_Windows.pdf\"><span class=\"comment\">Vers\u00e3o PDF<\/span><\/a><\/td>\n<\/tr>\n<\/table>\n<\/td>\n<\/tr>\n<\/table>\n<\/h3>\n<h3>1.\u00a0\u00a0\u00a0Introdu\u00e7\u00e3o <span>\u00a0\u00a0<\/span><a name=\"_Toc115021736\" title=\"_Toc115021736\"><\/a>Introdu\u00e7\u00e3o<span>\u00a0<\/span><\/h3>\n<p class=\"MsoNormal\"><span>\u00a0<\/span><span>Este documento foi escrito com intuito ajudar na instala\u00e7\u00e3o do servidor <span class=\"SpellE\">web<\/span> Apache no sistema operativo Microsoft Windows 2000 e XP. Trata-se apenas de um guia e n\u00e3o pretende substituir os manuais de utiliza\u00e7\u00e3o do Apache e do <span class=\"SpellE\">openssl<\/span>.<!--more--><\/span><\/p>\n<p style=\"margin-left: 0cm\" class=\"MsoNormal\"><span>\u00a0<\/span><span>Para facilitar na tarefa de cria\u00e7\u00e3o e gera\u00e7\u00e3o de certificados \u00e9 necess\u00e1rio configurar o ficheiro <span class=\"SpellE\">openssl.cnf<\/span>.<\/span><\/p>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Cria\u00e7\u00e3o chave do CA com 1024 bit<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> <span class=\"SpellE\">genrsa<\/span> -out <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.KEY<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Cria\u00e7\u00e3o do pedido de certificado<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> <span class=\"SpellE\">req<\/span> -new -key <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.KEY \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&#8211;<span class=\"GramE\">out<\/span> <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.CSR &#8211;<span class=\"SpellE\">config<\/span> <span class=\"SpellE\">openssl.cnf<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Certificado \u201c<span class=\"SpellE\">Self-sign<\/span>\u201d<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> x509 &#8211;<span class=\"SpellE\">req<\/span> -days 365 -in <span class=\"SpellE\">ssl.key<\/span>\/CA\/ CA.CSR \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&#8211;<span class=\"GramE\">out<\/span> <span class=\"SpellE\">ssl.key<\/span>\/CA\/ CA.CRT &#8211;<span class=\"SpellE\">signkey<\/span> <span class=\"SpellE\">ssl.key\/CA\/CA.key<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"GramE\"><span lang=\"EN-GB\">converter<\/span><\/span><span lang=\"EN-GB\"> <span class=\"SpellE\">para<\/span> <span class=\"SpellE\">pem<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> x509 -in <span class=\"SpellE\">ssl.key<\/span>\/ca\/CA.CRT &#8211;<span class=\"SpellE\">outform<\/span> DER \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-out <span class=\"SpellE\">ssl.key\/ca\/CA.der<\/span><\/span><\/p>\n<\/h3>\n<h3 style=\"margin-left: 36pt; text-indent: 0cm; tab-stops: 35.4pt\" class=\"Section1\"><span lang=\"EN-GB\"><\/span><\/h3>\n<h3 class=\"Section1\"><a name=\"_Toc115021742\" title=\"_Toc115021742\"><\/a><span><span>2.1.2.<span style=\"font-family: 'Times New Roman'\"> <\/span><\/span><\/span>Gera\u00e7\u00e3o de certificados para o web-server<\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Cria\u00e7\u00e3o chave do CA com des3 como m\u00e9todo de <span class=\"SpellE\">encripta\u00e7\u00e3o<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> <span class=\"SpellE\">genrsa<\/span> -des3 -out <span class=\"SpellE\">ssl.key\/server\/keys\/localhost.KEY<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Cria\u00e7\u00e3o do pedido de certificado<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> <span class=\"SpellE\">req<\/span> -new -key <span class=\"SpellE\">ssl.key\/server\/keys\/localhost.KEY<\/span> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-out <span class=\"SpellE\">ssl.key\/server\/requests\/<span class=\"GramE\">localhost.CSR<\/span><\/span><span class=\"GramE\"><span>\u00a0 <\/span>\\<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&#8211;<span class=\"SpellE\">config<\/span> <span class=\"SpellE\">openssl.cnf<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&nbsp;<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&nbsp;<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Assinar certificado com base no CA<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> ca &#8211;<span class=\"SpellE\">config<\/span> <span class=\"SpellE\">openssl.cnf<\/span> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-in <span class=\"SpellE\">ssl.key\/server\/requests\/localhost.CSR<\/span> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-cert <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.CRT \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&#8211;<span class=\"SpellE\">keyfile<\/span> <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.KEY \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-out <span class=\"SpellE\">ssl.key\/server\/certificates\/localhost.CRT<\/span><\/span><\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span lang=\"EN-GB\"><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span lang=\"EN-GB\"><\/span><\/h3>\n<h3 class=\"Section1\"><a name=\"_Toc115021743\" title=\"_Toc115021743\"><\/a><span><span>2.1.3.<span style=\"font-family: 'Times New Roman'\"> <\/span><\/span><\/span>Gera\u00e7\u00e3o de certificados para o web-browser<\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Cria\u00e7\u00e3o chave do CA com des3 como m\u00e9todo de <span class=\"SpellE\">encripta\u00e7\u00e3o<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> <span class=\"SpellE\">genrsa<\/span> -des3 -out <span class=\"SpellE\">ssl.key\/user\/keys\/user.KEY<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Cria\u00e7\u00e3o do pedido de certificado<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\">openssl<\/span><\/span> <span class=\"SpellE\">req<\/span> &#8211;<span class=\"SpellE\">new<\/span> \\<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&#8211;<span class=\"SpellE\">key<\/span> <span class=\"SpellE\">ssl.key<\/span>\/<span class=\"SpellE\">user<\/span>\/<span class=\"SpellE\">keys<\/span>\/<span class=\"SpellE\">user.KEY<\/span> \\<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-out <span class=\"SpellE\">ssl.key\/user\/requests\/<span class=\"GramE\">user.CSR<\/span><\/span><span class=\"GramE\"><span>\u00a0 <\/span>\\<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&#8211;<span class=\"SpellE\">config<\/span> <span class=\"SpellE\">openssl.cnf<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&nbsp;<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&nbsp;<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Assinar certificado com base no CA<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">openssl<\/span><\/span><\/span><span lang=\"EN-GB\"> ca &#8211;<span class=\"SpellE\">config<\/span> <span class=\"SpellE\">openssl.cnf<\/span> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-in <span class=\"SpellE\">ssl.key\/user\/requests\/user.CSR<\/span> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-cert <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.CRT \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&#8211;<span class=\"SpellE\">keyfile<\/span> <span class=\"SpellE\">ssl.key<\/span>\/CA\/CA.KEY \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">-out <span class=\"SpellE\">ssl.key\/user\/certificates\/user.CRT<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">Convers\u00e3o de certificado para formato PKCS#12 para importa\u00e7\u00e3o no<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">webbrowser<\/span><\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">openssl<\/span><\/span><\/span><span style=\"font-size: 10pt; color: #000000; font-family: Courier\"> pkcs12 -export &#8211;<span class=\"SpellE\">clcerts<\/span> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">-in <\/span><span class=\"SpellE\"><span lang=\"EN-GB\">ssl.key\/user\/certificates<\/span><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">\/user.CRT<\/span><\/span><span style=\"font-size: 10pt; color: #000000; font-family: Courier\"> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">&#8211;<span class=\"SpellE\">inkey<\/span> <\/span><span class=\"SpellE\"><span lang=\"EN-GB\">ssl.key\/user\/certificates<\/span><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">\/user.KEY<\/span><\/span><span style=\"font-size: 10pt; color: #000000; font-family: Courier\"> \\<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">-out <\/span><span lang=\"EN-GB\">ssl.key\/user\/certificates<\/span><span style=\"font-size: 10pt; color: #000000; font-family: Courier\">\/user.P12<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\"><\/span><\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span lang=\"EN-GB\"><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span lang=\"EN-GB\"><\/span><\/h3>\n<h1 class=\"Section1\"><a name=\"_Toc115021744\" title=\"_Toc115021744\"><\/a><span><span>3.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Configura\u00e7\u00e3o do Apache<\/h1>\n<h2 class=\"Section1\"><a name=\"_Toc115021745\" title=\"_Toc115021745\"><\/a><span><span>3.1.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Configura\u00e7\u00e3o base<\/h2>\n<h3 class=\"MsoNormal\"><span>Na <span class=\"SpellE\">webroot<\/span> do apache, no nosso <span class=\"GramE\">caso<span>\u00a0 <\/span><\/span>\/<span class=\"SpellE\">web<\/span>\/<span class=\"SpellE\">webroot<\/span>, tr\u00eas directorias:<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span class=\"GramE\"><span>normal<\/span><\/span><span>, aonde temos apenas <span class=\"SpellE\">ssl<\/span> activado.<\/span><\/h3>\n<h3 style=\"margin-left: 53.4pt\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span class=\"SpellE\"><span class=\"GramE\"><span>pro_normal<\/span><\/span><\/span><span>, aonde pretendemos uma protec\u00e7\u00e3o b\u00e1sica.<\/span><\/h3>\n<h3 style=\"margin-left: 53.4pt\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span class=\"SpellE\"><span class=\"GramE\"><span>pro_cert<\/span><\/span><\/span><span>, aonde pretendemos apenas utilizadores com certificados v\u00e1lidos.<\/span><\/h3>\n<h3 style=\"margin-left: 53.4pt\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span class=\"SpellE\"><span class=\"GramE\"><span>pro_sel_cert<\/span><\/span><\/span><span>, aonde pretendemos apenas utilizadores escolhidos com certificados v\u00e1lidos.<\/span><\/h3>\n<h3 style=\"margin-left: 56.25pt\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h2 class=\"Section1\"><a name=\"_Toc115021746\" title=\"_Toc115021746\"><\/a><span><span>3.2.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Activa\u00e7\u00e3o do SSL para todas as \u00e1reas<\/h2>\n<h3 class=\"MsoNormal\"><span>Para ter conte\u00fados protegidos com <span class=\"SpellE\">ssl<\/span>, temos duas solu\u00e7\u00f5es:<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span>Proteger todo o site, removendo o porto 80 mantendo o porto <span class=\"SpellE\">ssl<\/span> 443.<\/span><\/h3>\n<h3 style=\"margin-left: 53.4pt\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span>Proteger cada directoria pretendendo no ficheiro <span class=\"SpellE\">httpd.conf<\/span>.<\/span><\/h3>\n<h3 style=\"margin-left: 0cm\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Vou apresentar o segundo caso.<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Assim \u00e9 necess\u00e1rio alterar, no <span class=\"SpellE\">httpd.conf<\/span>, a configura\u00e7\u00e3o das pastas <span class=\"SpellE\">pro_normal<\/span>, <span class=\"SpellE\">pro_cert<\/span> e <span class=\"SpellE\">pro_sel_cert<\/span> para ser alvo de protec\u00e7\u00e3o <span class=\"SpellE\">ssl<\/span>.<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Um exemplo dessa altera\u00e7\u00e3o \u00e9:<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&lt;Directory \/web\/<span class=\"SpellE\">webroot\/pro_normal<\/span>\/&gt;<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\">SSLRequireSSL<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&lt;\/<span class=\"SpellE\">Directory<\/span>&gt;<\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h2 class=\"Section1\"><a name=\"_Toc115021747\" title=\"_Toc115021747\"><\/a><span><span>3.3.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Restri\u00e7\u00e3o pelo m\u00e9todo cl\u00e1ssico usando o htpassfile<\/h2>\n<h3 class=\"MsoNormal\"><span>Para definir que utilizadores podem aceder a directoria \u00e9 necess\u00e1rio criar um ficheiro contendo os <span class=\"SpellE\">login<\/span>\/<span class=\"SpellE\"><span class=\"GramE\">password<\/span><\/span> dos utilizadores autorizados. Temos de criar ent\u00e3o o ficheiro \/<span class=\"SpellE\">web<\/span>\/apache\/<span class=\"SpellE\">conf<\/span>\/htpassfile.txt. <\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Essa gest\u00e3o \u00e9 feita com base no comando <span class=\"SpellE\">htpasswd<\/span> do apache. Como exemplo, dois utilizadores, <span class=\"SpellE\">admusr<\/span> e usr1, os comandos ser\u00e3o algo como:<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">htpasswd<\/span><\/span><\/span><span lang=\"EN-GB\"> \u2013<span class=\"SpellE\">bc<\/span> \/web\/apache\/conf\/htpassfile.txt <span class=\"SpellE\">admusr<\/span> pass<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\"><span lang=\"EN-GB\">htpasswd<\/span><\/span><\/span><span lang=\"EN-GB\"> \u2013c \/web\/apache\/conf\/htpassfile.txt usr1 pass<\/span><\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span lang=\"EN-GB\"><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>A op\u00e7\u00e3o <span class=\"SpellE\">c<\/span> permite que o <span class=\"SpellE\">htpasswd<\/span> cria o ficheiro se n\u00e3o existir.<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>A op\u00e7\u00e3o <span class=\"SpellE\">b<\/span> indica ao <span class=\"SpellE\">htpasswd<\/span> que a <span class=\"SpellE\"><span class=\"GramE\">password<\/span><\/span> \u00e9 definida como par\u00e2metro.<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Dentro da pasta <span class=\"SpellE\">pro_normal<\/span>, \u00e9 necess\u00e1rio criar um <span class=\"GramE\">ficheiro .<span class=\"SpellE\">htaccess<\/span><\/span> contendo o seguinte:<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span lang=\"EN-GB\">AuthUserFile<\/span><\/span><span lang=\"EN-GB\"> \/web\/apache\/conf\/htpassfile.txt<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\">AuthName<\/span> &#8220;SR Autentica\u00e7\u00e3o&#8221;<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\">AuthType<\/span> Basic<\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span class=\"GramE\">require<\/span><\/span> <span class=\"SpellE\">valid-user<\/span><\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Assim indicamos ao Apache que todos os acessos nesta directoria s\u00e3o para ser validados com base no ficheiro htpassfile.txt<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 0cm\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h2 class=\"Section1\"><a name=\"_Toc115021748\" title=\"_Toc115021748\"><\/a><span><span>3.4.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Restri\u00e7\u00e3o usando certificados<\/h2>\n<h3 class=\"MsoNormal\"><span>Para restringir os utilizadores para apenas os que tenham certificados compat\u00edveis com o do servidor \u00e9 necess\u00e1rio configurar no ficheiro <span class=\"SpellE\">httpd.conf<\/span> do apache de seguinte maneira: <\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&lt;Directory \/web\/<span class=\"SpellE\">webroot\/pro_cert<\/span>\/&gt;<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\">SSLRequireSSL<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\">SSLVerifyClient<\/span> <span class=\"SpellE\">require<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&lt;\/Directory&gt;<\/span><\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span lang=\"EN-US\"><\/span><\/h3>\n<h2 class=\"Section1\"><a name=\"_Toc115021749\" title=\"_Toc115021749\"><\/a><span><span>3.5.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Restri\u00e7\u00e3o usando certificados controlados.<\/h2>\n<h3 class=\"MsoNormal\"><span>Para restringir os utilizadores para apenas os que tenham certificados compat\u00edveis com o do servidor e escolhidos \u00e9 necess\u00e1rio configurar no ficheiro <span class=\"SpellE\">httpd.conf<\/span> do apache de seguinte maneira: <\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"padding-right: 4pt; padding-left: 4pt; background: silver; padding-bottom: 1pt; margin-left: 35.4pt; margin-right: 0cm; padding-top: 1pt; border: windowtext 1pt solid\" class=\"Section1\">\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span lang=\"EN-GB\">&lt;Directory \/web\/<span class=\"SpellE\">webroot\/pro_cert<\/span>\/&gt;<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span lang=\"EN-GB\">SSLRequireSSL<\/span><\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span lang=\"EN-GB\">SSLVerifyClient<\/span><\/span><span lang=\"EN-GB\"> require<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\"><span class=\"SpellE\"><span lang=\"EN-GB\">SSLRequire<\/span><\/span><span lang=\"EN-GB\"><span>\u00a0\u00a0\u00a0 <\/span>%<span class=\"GramE\">{SSL<\/span>_CLIENT_S_DN_O} <span class=\"SpellE\">eq<\/span> \u201cUser <span class=\"SpellE\">xpto<\/span>\u201d<\/span><\/p>\n<p style=\"background: silver; margin-left: 0cm\" class=\"Config\">&lt;\/<span class=\"SpellE\">Directory<\/span>&gt;<\/p>\n<\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Nota: Podemos alterar a configura\u00e7\u00e3o do <span class=\"SpellE\">SSLRequire<\/span> para validar com base noutros par\u00e2metros tais como <\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span>SSL_CLIENT_S_DN_CN, alcunha do utilizador, \u201c<span class=\"SpellE\">Common<\/span> <span class=\"SpellE\">Name<\/span>\u201d<\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span>SSL_CLIENT_S_DN_O, nome da organiza\u00e7\u00e3o.<\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span>SSL_CLIENT_S_DN, Nome completo do <span class=\"SpellE\">utilziador<\/span><\/span><\/h3>\n<h3 style=\"margin-left: 71.4pt; text-indent: -18pt; tab-stops: list 71.4pt\" class=\"MsoNormal\"><span style=\"font-family: Symbol\"><span>\u00b7<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span><span>SSL_CLIENT_CERT, o certificado em base 64.<\/span><\/h3>\n<h3 style=\"margin-left: 0cm\" class=\"MsoNormal\"><span><\/span><\/h3>\n<h3><\/h3>\n<p><em><span style=\"font-size: 11pt; font-family: Arial\"><\/span><\/em><em><span style=\"font-size: 11pt; font-family: Arial\"><\/p>\n<h3 class=\"Section1\"><br style=\"page-break-before: always\" \/><\/h3>\n<h3><\/h3>\n<p><\/span><\/em><\/p>\n<h2 class=\"Section1\"><a name=\"_Toc115021750\" title=\"_Toc115021750\"><\/a><span><span>3.6.<span style=\"font-family: 'Times New Roman'\">\u00a0\u00a0\u00a0\u00a0\u00a0 <\/span><\/span><\/span>Testes.<\/h2>\n<h3 style=\"margin-left: 36pt; text-indent: 0cm; tab-stops: 35.4pt\" class=\"Section1\"><\/h3>\n<h3 class=\"MsoNormal\"><span>Aqui est\u00e3o exemplos de testes <span class=\"GramE\">com <span>\u00a0<\/span>o<\/span> <span class=\"SpellE\">FireFox<\/span> e o Internet Explorer. <\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoNormal\"><span lang=\"EN-US\"><img decoding=\"async\" loading=\"lazy\" width=\"510\" src=\"\/gfx\/Apache_SSL_Windows_ficheiros\/image001.png\" height=\"315\" style=\"width: 449px; height: 278px\" \/><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoCaption\"><a name=\"_Toc104909911\" title=\"_Toc104909911\"><\/a><span>Figura <\/span><span><span>1<\/span><\/span><span><span> \u2013 Falha na tentativa de acesso aos conte\u00fados <span class=\"SpellE\">ssl<\/span>.<\/span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoNormal\"><span lang=\"EN-US\"><img decoding=\"async\" src=\"\/gfx\/Apache_SSL_Windows_ficheiros\/image003.png\" \/><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoCaption\"><a name=\"_Toc104909912\" title=\"_Toc104909912\"><\/a><span>Figura <\/span><span><span>2<\/span><\/span><span><span> <span class=\"GramE\">&#8211;<\/span> Teste com m\u00e9todo de autentica\u00e7\u00e3o b\u00e1sico.<\/span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoNormal\"><span lang=\"EN-US\"><img decoding=\"async\" src=\"\/gfx\/Apache_SSL_Windows_ficheiros\/image005.png\" \/><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoCaption\"><a name=\"_Toc104909913\" title=\"_Toc104909913\"><\/a><span>Figura <\/span><span><span>3<\/span><\/span><span><span> \u2013 Pedido da <span class=\"GramE\">palavra chave<\/span> no <span class=\"SpellE\">FireFox<\/span>.<\/span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span>Foi interessante ver que o <span class=\"SpellE\">firefox<\/span>, ao contr\u00e1rio do IE, pede a palavra-chave do certificado para poder ser utilizado.<\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 class=\"MsoNormal\"><span><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoNormal\"><span lang=\"EN-US\"><img decoding=\"async\" src=\"\/gfx\/Apache_SSL_Windows_ficheiros\/image007.png\" \/><\/span><\/h3>\n<h3 style=\"text-align: center\" class=\"MsoCaption\"><a name=\"_Toc104909914\" title=\"_Toc104909914\"><\/a><span>Figura <\/span><span><span>4<\/span><\/span><span><span> \u2013 Pedido de certificado no IE.<\/span><\/span><\/h3>\n<h3><\/h3>\n<p><\/span><\/span><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Instala\u00e7\u00e3o do servidor web Apache em Windows com SSL<\/p>\n","protected":false},"author":3,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[5,22,4],"tags":[29],"_links":{"self":[{"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/posts\/15"}],"collection":[{"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/comments?post=15"}],"version-history":[{"count":1,"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/posts\/15\/revisions"}],"predecessor-version":[{"id":259,"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/posts\/15\/revisions\/259"}],"wp:attachment":[{"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/media?parent=15"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/categories?post=15"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.apmuga.com\/wordpress\/wp-json\/wp\/v2\/tags?post=15"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}