Como verificar si un destino en Internet se encuentra bloqueado
Hola,
Si en google por ejemplo buscamos "como revisar si un sitio web esta bloqueado" será difícil conseguir información de como revisar **nosotros mismos, ** los resultados serán principalmente sitios Web que pueden abrir la página Web por tí, mostrarte desde otros sitio si puede conectarse, algún plugin que puedas instalar. En estás páginas se puede revisar si un sitio está arriba o no: https://www.blocked.org.uk/check y https://downforeveryoneorjustme.com/
NOTA: Este post es básicamente como podemos revisar nosotros mismos un bloqueo. Estamos hablando de bloqueos por parte de un ISP/país, no de bloqueos en el firewall en una empresa o compañía. Se aceptan sugerencias y quejas.
Introducción:
Como algunos de ustedes saben, existen muchas manera de bloquear sitios Web, principalmente los bloqueos ocurren de 4 maneras:
1) DNS
2) Routing
3) Capa 4 (bloqueo de puertos TCP/UDP a ciertos destinos)
4) Capa 7 (bloqueo de por ejemplo la URL/dominio)
Ahora bien, antes de continuar quiero dejar claro mi posición en cuanto a los bloqueos en Internet: ME PARECEN MUY MALA IDEA y no trae nada bueno al país/ISP…, y en el supuesto que traíga una cosa buena, trae 10 cosas malas. Tengo algunas cosas plasmadas en este post: https://blog.acostasite.com/2014/10/la-mala-idea-de-bloquear-internet.html
Pasos para revisar un bloqueo de un sitio Web:
Ahora bien, en el supuesto que queramos saber si algún sitio se encuentra bloqueado, podemos seguir estos pasos (preferiblemente Linux y/o MAC):
1) Revisar si el bloqueo es por DNS. ¿Cómo lo hacemos?
Podemos usar dos herramientas de resolución DNS. Para este ejemplo utilizaremos dig y/o nslookup.
.- Utilizando dig
MacBook-Pro-2:tmp$ dig +short www.example.com
172.XX.YY.39
.- Utilizando nslookup
MacBook-Pro-2:tmp$ nslookup www.example.com
Server: 8.8.8.8
Address: 8.8.8.8#53
Non-authoritative answer:
Name: www.example.com
Address: 172.XX.YY.39
¿Qué hay que revisar de la salida?
Básicamente con el comando, le pedimos a dig que muestre de manera resumida, que direcciones IP resuelve www.example.com. En este sentido 172.XX.YY.39 será el IP al cual nuestra computadora se va a conectar. Lo importante aquí es identificar si 172.XX.YY.39 corresponde al IP destino que nos queremos conectar (si, ciertamente pueden resolver direcciones diferentes y eso, pero si sabes eso no necesitas leer este documento :) !! ) Muchas veces algunos ISPs cambian la resolución de un dominio y no verías el IP correcto sino otra al cual es imposible conectarse (por ejemplo, 127.0.0.1)
2) Routing
Para revisar routing principalmente utilizaremos traceroute (tracert en Windows)
La idea es en lineas generales ver si podemos alcanzar el destino desde nuestra computadora:
Utilizando traceroute:
MacBook-Pro-2:tmp$ traceroute -n 8.8.8.8 __(sustituye 8.8.8.8 por el dominio o el IP obtenido en el paso previo)
traceroute to 8.8.8.8 (8.8.8.8), 64 hops max, 52 byte packets
1 192.168.1.1 1.724 ms 1.030 ms 1.376 ms_
2 190.XX.XX.1 28.969 ms * 35.939 ms_
3 172.YY.13.33 27.988 ms 27.379 ms 29.267 ms_
4 * * *_
5 10.XX.1.105 29.229 ms 28.628 ms 28.303 ms_
6 10.XX.1.1 38.332 ms 26.855 ms 28.605 ms_
7 200.XX.XX.177 61.560 ms 62.466 ms 68.661 ms_
8 72.NN.NN.84 62.411 ms 62.523 ms 62.188 ms_
9 108.170.253.17 62.537 ms 63.011 ms 63.182 ms_
10 108.170.226.13 63.588 ms 65.335 ms 62.301 ms_
11 8.8.8.8 62.329 ms 63.023 ms 62.176 ms_
¿Qué hay que revisar de la salida?
Como se puede ver en el traceroute de arriba, se llegó satisfactoriamente al destino.
En el caso de ver algún "!" seguido por una letra, es mala noticia. Por ejemplo ver esto en el traceroute significa que hay algo mal, quizás el ISP bloqueó las direcciones IP destino de alguna manera.
Errores comunes (tomados de la página del manual de traceroute):
!H , _ !N _, or _ !P _ (host, network or protocol unreachable)
!S _ (source route failed)_
!U _ or _ !W _ (destination network/host unknown) _
** !I** _ (source host is isolated)_
!A _ (communication with destination network administratively prohibited)_
!Z _ (communication with destination host administratively prohibited)_
!Q _ (for this ToS the destination network is unreachable), _
** !T** _ (for this ToS the destination host is unreachable), _
** !X** _ (communication administratively prohibited), _
** !V** _ (host precedence violation), _
** !C** _ (precedence cutoff in effect), or _
** ! **_ (ICMP unreachable code ). _
Extra:
Otra herramienta que recomiendo para revisar este punto es MTR (My traceroute) ; https://es.wikipedia.org/wiki/MTR_(software).., es una combinación de ping y trace. MUY buena.
3) Capa 4 (bloqueo de puertos a ciertos destinos)
Para revisar bloqueos de capa 4, principalmente la idea es revisar conectividad a nivel de puertos (TCP) desde tu computadora al destino.
La herramienta más sencilla para revisar esto es telnet, la intención al ejecutarlo es chequear que efectivamente "se conectó" nuestra computadora al destino.
Utilizando telnet:
Ejemplo 1: (conecta¡ándose al puerto http)
MacBook-Pro-2:tmp$ telnet www.example.com 80
Trying 199.NN.NN.100…
Connected to www.example.com. <— esto es lo que hay que revisar
Escape character is '^]'.
Ejemplo 1: (conectándose al puerto https)
MacBook-Pro-2:tmp$ telnet www.example.com 443
Trying 199.NN.NN.100…
Connected to www.example.com. <— esto es lo que hay que revisar
Escape character is '^]'.
Cuando el destino se encuentra bloqueado a nivel de 4 veríamos algo así:
MacBook-Pro-2:tmp$ telnet www.example.com 80
Trying 199.XX.XX.100…
telnet: connect to address 199.XX.NN.100: Operation timed out
telnet: Unable to connect to remote host
Depende el tipo de bloqueo, el telnet puede ser rechazado muy rápido (reject *), quizás el telnet solo dure mucho hasta que haga timeout.
* tu computadora recibe un icmp error desde el dispositivo que se encuentra bloqueando
4) Capa 7 (bloqueo de por ejemplo la URL/dominio)
Revisar capa 7 viene a ser cuando el ISP es capaz de identificar el contenido de paquetes HTTP y chequear por el texto del dominio bloqueado dentro de él, es decir: el ISP quiere bloquear www.example.com, algunos dispositivos dentro del ISP son capaces de revisar a nivel de capa de aplicación (capa 7) el fqdn www.example.com, y allí tomar la decisión: bloquear o no.
Para lo anterior, recomiendo utilizar curl o wget. Dejaré solo el ejemplo con curl:
Utilizando curl (en hacia un destino bloqueado)
MacBook-Pro-2:tmp$ curl -v https://www.example.com
* Rebuilt URL to: https://www. example.com/
* Trying 172.NN.NN.39…
* TCP_NODELAY set
* Connected to www.example.com (172.NN.NN.39) port 443 (#0)
* ALPN, offering h2
* ALPN, offering http/1.1
* Cipher selection: ALL:!EXPORT:!EXPORT40:!EXPORT56:!aNULL:!LOW:!RC4:@STRENGTH
* successfully set certificate verify locations:
* CAfile: /etc/ssl/cert.pem
_ CApath: none_
* TLSv1.2 (OUT), TLS handshake, Client hello (1):
_* LibreSSL SSL_connect: SSL_ERROR_SYSCALL in connection to www.example.com:443 _
* stopped the pause stream!
* Closing connection 0
_curl: (35) LibreSSL SSL_connect: SSL_ERROR_SYSCALL in connection to www.example.com:443 _
¿Qué hay que revisar de la salida?
No hay que asustarse con la salida, aquí hay revisar que la negociación SSL/TLS no pudo completarse, esto lo podemos apreciar al conseguir que el texto *ERROR* se ve en la salida.
Nota: Cuando la salida es satisfactoria, veremos código html
Conclusión:
** ** Existen MUCHAS manera de bloquear acceso a sitios en Internet, incluso en algunas oportunidades puede usarse una combinación de varias maneras para lograr un bloqueo.
Se que el post puede ser mucho más amplio y faltaron cosas por cubrir, sin embargo a su vez espero que él mismo sea visto como una introducción.
El bloqueo de sitios Web en Internet no trae beneficios.