
Quiero que todo mi tráfico a un dominio específico se envíe a través de un proxy principal, aquí está mi configuración de squid:
acl localnet src 10.0.0.0/8 # RFC1918 possible internal network
acl localnet src 172.16.0.0/12 # RFC1918 possible internal network
acl localnet src 192.168.0.0/16 # RFC1918 possible internal network
acl localnet src fc00::/7 # RFC 4193 local private network range
acl localnet src fe80::/10 # RFC 4291 link-local (directly plugged) machines
acl SSL_ports port 443
acl Safe_ports port 80 # http
acl Safe_ports port 21 # ftp
acl Safe_ports port 443 # https
acl Safe_ports port 70 # gopher
acl Safe_ports port 210 # wais
acl Safe_ports port 1025-65535 # unregistered ports
acl Safe_ports port 280 # http-mgmt
acl Safe_ports port 488 # gss-http
acl Safe_ports port 591 # filemaker
acl Safe_ports port 777 # multiling http
acl CONNECT method CONNECT
http_access allow manager localhost
http_access allow localhost
http_access allow localnet
http_access deny manager
http_access deny !Safe_ports
http_access deny all
http_access allow localnet
http_access allow localhost
http_access deny all
http_port 3128
hierarchy_stoplist cgi-bin ?
coredump_dir /var/spool/squid
refresh_pattern ^ftp: 1440 20% 10080
refresh_pattern ^gopher: 1440 0% 1440
refresh_pattern -i (/cgi-bin/|\?) 0 0% 0
refresh_pattern . 0 20% 4320
cache_peer XXX.XXX.XXX.XXX parent 3128 0 no-digest
cache_peer_domain XXX.XXX.XXX.XXX .srv-get-my-ip.com
Entonceshttp://ip.srv-get-my-ip.comse envía bien a través del proxy ya que devuelve Current Address: XXX.XXX.XXX.XXX
:
1444889588.794 599 192.168.0.12 TCP_MISS/200 522 GET http://ip.srv-get-my-ip.com/ - FIRSTUP_PARENT/XXX.XXX.XXX.XXX text/html
Perohttps://ip.srv-get-my-ip.comno se envía a través del proxy ya que devuelve mi ip Current Address: YYY.YYY.YYY.YYY
:
1444889762.199 154 192.168.0.12 TCP_MISS/200 6654 CONNECT ip.srv-get-my-ip.com:443 - HIER_DIRECT/AAA.AAA.AAA.AAA -
¿Cómo puedo hacer que Squid procese la segunda consulta de la misma manera que la primera?
El resultado importa aquí, así que si alguien puede lograr el mismo objetivo usando otro proxy que no sea Squid (apache, haproxy o lo que sea), ¡lo intentaría!
¡Gracias!
Respuesta1
Se puede realizar el proxy SSL de la manera que usted describe, perorequiere[1] que tienes los certificados SSL en tu poder.
Esta es una característica, no un error, porque previene ataques de intermediario contra SSL.
Si está en posesión de los certificados, la mayoría de los servidores proxy inversos funcionarán para usted. Puede, por ejemplo, configurar squid para finalizar la conexión SSL y luego restablecerla hacia el proxy principal. Ver elDocumentación https de calamar
Nota también de esa página:
HTTPS fue diseñado para brindar a los usuarios una expectativa de privacidad y seguridad. Descifrar túneles HTTPS sin el consentimiento o conocimiento del usuario puede violar normas éticas y puede ser ilegal en su jurisdicción.
nginx,Servidor de tráfico Apache,HAProxy, Apache httpd conmod_proxyy varios otros servidores proxy inversos son capaces de realizar la terminación SSL por usted.
[1] Hay excepciones si puede tolerar HTTPS inseguro o (quizás más interesante) si puede controlar los certificados confiables en los clientes. Pero... en ese camino hay peligro.