Vis*_*nda 6 c python sockets routing
我有一个限制性防火墙后面的连接,它只允许通过代理(10.10.1.100:9401)进行HTTP(S)访问.我得到的IP地址是动态的,子网掩码是255.255.255.255(我知道,很奇怪!).
我尝试编写一个简单的Python套接字程序来连接代理,以便发送一些HTTP请求:
import socket
s = socket.socket( socket.AF_INET, socket.SOCK_STREAM )
s.connect(( "10.10.1.100", 9401 ))
s.send("GET /index.html HTTP/1.1\r\nHost: aorotos.com\r\n\r\n")
d = s.recv(1024)
print d
s.close()
Run Code Online (Sandbox Code Playgroud)
在连接期间,我得到一个例外(113,"无主机路由").现在这里是奇怪的部分 - 我可以使用这些相同的代理设置浏览网页,如果通过netstat -tna我检查当前连接的套接字,我会看到与10.10.1.100:9401的ACTIVE连接.
我尝试了一个简单的命令export http_proxy='10.10.1.100:9401' && wget aorotos.com/index.html,甚至可行!如果我-d在wget中启用调试选项(),我甚至可以获得套接字的文件描述符.
我浏览了wget源代码,从我所看到的它也使用了一个普通的连接语句,并没有设置任何特殊的套接字选项(我将在以后更详细地介绍它).我在C中尝试了相同的代码,它也失败了.
通过提供的路由表route是
Destination Gateway Genmask Flags Metric Ref Use Iface
default * 0.0.0.0 U 0 0 0 gprs0
Run Code Online (Sandbox Code Playgroud)
有谁知道什么可能是错的?
编辑:目前我的IP是10.16.82.250.这就是route输出中的所有内容.如果您感兴趣我的外部IP是203.8.8.2.
ifconfig gprs0 -
gprs0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
inet addr:10.17.221.94 P-t-P:10.17.221.94 Mask:255.255.255.255
UP POINTOPOINT RUNNING NOARP MTU:1400 Metric:1
RX packets:1832 errors:0 dropped:0 overruns:0 frame:0
TX packets:1844 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:1878364 (1.7 MiB) TX bytes:224746 (219.4 KiB)
Run Code Online (Sandbox Code Playgroud)
编辑2:我登陆安装tcpdump并通过它的手册,最后安装wireshark(我在我的N900上)只是为了从数据包转储中实现我在两者中都使用了端口4901而不是9401 C程序和python脚本!卫生署!我责怪小屏幕,好吧,我自己.
有没有办法用"我是白痴"或其他东西来解决这个问题?:P抱歉占用你的时间!(我花了一个多星期的时间.我不敢相信我经历了大部分wget的源代码!)