Python 批量获取代理服务器IP并测试

转载:http://blog.csdn.net/abcamus/article/details/52993711

#-*-coding:utf-8 -*-
import urllib2
import BeautifulSoup
import codecs

User_Agent = 'Mozilla/5.0 (Windows NT 6.3; WOW64; rv:43.0) Gecko/20100101 Firefox/43.0'
header = {}
header['User-Agent'] = User_Agent

url = 'http://www.xicidaili.com/nn/1'
req = urllib2.Request(url,headers=header)
res = urllib2.urlopen(req).read()

soup = BeautifulSoup.BeautifulSoup(res)
ips = soup.findAll('tr')
f = codecs.open("./proxy","w", 'utf-8')

for x in range(1, len(ips)):
    ip = ips[x]
    tds = ip.findAll("td")
    ip_temp = tds[1].contents[0]+"\t"+tds[2].contents[0]+"\n"
    f.write(ip_temp)
f.close()

import urllib
import socket
socket.setdefaulttimeout(3)
f = open("./proxy")
fd_proxy = codecs.open("./access.txt", "w", 'utf-8')
lines = f.readlines()
proxys = []
for i in range(0, len(lines)):
    ip = lines[i].strip("\n").split("\t")
    proxy_host = "http://" + ip[0] + ":" + ip[1]
    proxy_temp = {"http":proxy_host}
    proxys.append(proxy_temp)
url = "http://ip.chinaz.com/getip.aspx"
for proxy in proxys:
    try:
        res = urllib.urlopen(url,proxies=proxy).read()
        fd_proxy.write(proxy["http"]+"\n")
        print res
    except Exception,e:
        print proxy
        print e
        continue
f.close()
fd_proxy.close()
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49

我们获取的代理服务器网址位于 http://www.xicidaili.com/nn/1

里面会经常更新可用的代理服务器ip,如图所示 
这里写图片描述

在safari浏览器页面右键弹出快捷菜单,选择显示页面源文件就能看到如下界面:

这里写图片描述

我们先获得tr字段,然后从tr字段中选择ip地址所在的td字段就能把代理服务器地址给提取出来,同样的方法提取端口号,然后保存为文件proxy。

保存下来后,不能保证每一个代理服务器地址都是可以连接的,需要进行测试,后半部分代码就是把保存在proxy文件中的ip地址一个个拿出来,通过访问页面 http://ip.chinaz.com/getip.aspx 进行测试。

Python语言是一种非常适合网络编程的语言,并且具有很多网络编程库。要批量探测IP地址的存活性,我们可以使用Python的socket库。此外,要发送电子邮件,我们可以使用Python内置的smtplib模块。如果需要发送纯文本邮件,用SMTP邮件协议即可。如果需要发送HTML邮件,则需要使用MIME邮件协议。 批量探测IP地址存活性的方法是:使用ping命令,向目标主机发送ICMP封包,如果目标主机收到ICMP封包,它会回送一个ICMP封包,表示自己的存活状态。通过判断返回数据包中的状态码和延迟等指标,就可以判断目标主机的存活状态。 下面是一个简单的Python代码段,可以实现批量探测IP地址存活性和发送邮件告警: ```python #导入必要的模块 import subprocess import smtplib #定义目标IP地址列表 targets = ['192.168.1.1','192.168.1.2','192.168.1.3'] #遍历目标地址列表 for target in targets: #执行ping命令并获取结果 response = subprocess.Popen(['ping', '-c', '1', target], stdout=subprocess.PIPE).communicate()[0] #提取ping结果中的状态码 response_status = int(response.split('\n')[-3].split()[3]) #判断状态码并发送邮件告警 if response_status == 0: #如果存活,就不发送邮件 pass else: #如果不存活,就发送邮件 server = smtplib.SMTP('smtp.gmail.com', 587) server.starttls() server.login('youremail@gmail.com', 'yourpassword') message = 'Subject: IP Address Alert\n\n' + target + ' is not responding to ping.' server.sendmail('youremail@gmail.com', 'recipient@example.com', message) server.quit() ``` 在以上代码中,`targets`是要探测的IP地址的列表。通过遍历列表中的每个IP地址,使用`subprocess.Popen`函数执行ping命令并获取响应结果。判断响应结果中包含的状态码,如果为0,表示IP地址存活;如果为其他值,就发送邮件告警。要发送邮件,需要使用SMTP协议连接到email服务器,并调用`server.login`和`server.sendmail`函数。如果成功,就会发送一封电子邮件给指定的收件人。 总之,Python语言在批量探测IP地址存活性和发送邮件告警方面非常灵活。以上代码只是一个简单的例子,可以根据需要进行修改和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值