C段http_banner获取v0.3

更新:

1.使用optparse来获取命令行参数

#-*-coding=utf-8-*-
# __author__  = ‘sanr‘
# __email__   = ‘[email protected]‘
# __url__     = ‘http://0x007.blog.51cto.com/‘
# __version__ = ‘0.3‘
import requests
import re
from threading import Thread,Lock
import sys
import chardet
import netaddr
import struct
import socket
import os
import optparse

lock = Lock()

def ip2int(addr):
	return struct.unpack("!I", socket.inet_aton(addr))[0]
def int2ip(addr):
	return socket.inet_ntoa(struct.pack("!I", addr))
def int_dec(pagehtml):

	charset = None
	if pagehtml != ‘‘:
		# print ‘use charset dect‘
		enc = chardet.detect(pagehtml)
		# print ‘enc= ‘, enc
		if enc[‘encoding‘] and enc[‘confidence‘] > 0.9:
			charset = enc[‘encoding‘]

		if charset == None:
			charset_re = re.compile("((^|;)\s*charset\s*=)([^\"‘]*)", re.M)
			charset=charset_re.search(pagehtml[:1000]) 
			charset=charset and charset.group(3) or None

		# test charset
		try:
			if charset:
				unicode(‘test‘,charset,errors=‘replace‘)
		except Exception,e:
			print ‘Exception‘,e
			charset = None
	# print ‘charset=‘, charset
	return charset

def http_banner(url):
	ip=url
	try:
		url=requests.get(url,timeout=2)	

		body = url.content

		charset = None
		if body != ‘‘:
			charset = int_dec(body)

		if charset == None or charset == ‘ascii‘:
			charset = ‘ISO-8859-1‘

		if charset and charset != ‘ascii‘ and charset != ‘unicode‘:
			try:
				body = unicode(body,charset,errors=‘replace‘)
			except Exception, e:
				body = ‘‘

		Struts=url.status_code

		Server=url.headers[‘server‘][0:13]

		if Struts==200 or Struts==403 or Struts==401:
			title=re.findall(r"<title>(.*)<\/title>",body)
			if len(title):
				title = title[0].strip()
			else:
				title = ‘‘
			#输出加锁 防止第二行输入
			#申请锁
			lock.acquire()
			print (‘%s\t%d\t%-10s\t%s‘%(ip.lstrip(‘http://‘),Struts,Server,title))
			#释放锁
			lock.release()
	except (requests.HTTPError,requests.RequestException,AttributeError,KeyError),e:
		pass

if __name__ == ‘__main__‘:
	parser = optparse.OptionParser(‘usage: %prog [options] target‘)
	parser.add_option(‘-p‘, ‘--port‘, dest=‘port‘, default=‘80‘,type=‘string‘, help=‘Port.default = 80‘)
	(options,args) = parser.parse_args() #parser.parse_args处理之后给option返回一个字典对象,对象的key就是你上面设置的dest的值

	if len(args) < 1:
		parser.print_help()
		print ‘usage: python %s 218.92.227.1/24 ‘%os.path.basename(sys.argv[0])
		print ‘usage: python %s 218.92.227.1-218.92.227.254 ‘%os.path.basename(sys.argv[0])
		print ‘usage: python %s 218.92.227.1./24 -p 8080‘%os.path.basename(sys.argv[0])
		print ‘usage: python %s 218.92.227.1-218.92.227.254 -p 8080‘%os.path.basename(sys.argv[0])
		sys.exit(0)

	ips=args[0]
	port=options.port
	if ‘-‘ in ips:
		start, end = ips.split(‘-‘)
		startlong = ip2int(start)
		endlong = ip2int(end)
		ips = netaddr.IPRange(start,end)
		for ip in list(ips):
			url=‘http://%s:%s‘%(ip,port)
			t = Thread(target=http_banner,args=(url,))
			t.daemon=False
			t.start()
	elif ‘/‘	in ips:
		ips = netaddr.IPNetwork(ips)
		for ip in list(ips):
			url=‘http://%s:%s‘%(ip,port) 
			t = Thread(target=http_banner,args=(url,))
			t.daemon=False
			t.start()
时间: 2024-10-14 08:55:23

C段http_banner获取v0.3的相关文章

C段http_banner获取v0.2

#-*-coding=utf-8-*- # __author__  = 'sanr' # __email__   = '[email protected]' # __url__     = 'http://0x007.blog.51cto.com/' # __version__ = '0.2' import requests import re from threading import Thread,Lock import time import sys import chardet impo

C段http_banner获取

#-*-coding=utf-8-*- # __author__  = 'sanr' # __email__   = '[email protected]' # __url__     = 'http://0x007.blog.51cto.com/' # __version__ = '0.1' import requests import re from threading import Thread,Lock import time import sys import chardet impo

http_banner获取2.0

更新如下 端口可自定义 默认80 线程可自定义 默认10 使用了队列存消息 #-*-coding=utf-8-*- # __author__  = 'sanr' # __email__   = '[email protected]' # __url__     = 'http://0x007.blog.51cto.com/' # __version__ = '2.0' import requests import re import sys from threading import Threa

分享一段php获取任意时间的前一天代码

<?php /** * 获取给定日期的前一天 * @param string $date * @return string $yesterday */ function getYesterday($date) { if(empty($date)) { $yesterday = date("Y-m-d",strtotime("-1 day")); }else{ $arr = explode('-', $date); $year = $arr[0]; $month

提供一段Excel获取Title的标题,类似于A、AA、AAA,我们操作Excel的时候通常根据次标题来获取一定的操作范围。

/******************************************** FormatExcelColumTitle Purpose Get excel title like "A","AA","AAB".. by the column index. we can use the string to specified single cell with the row number. Params strTitle - [out

Scala 获取指定目录下的所有文件名(不包括目录名)

最近在学习Scala,想要获取指定目录下的所有文件名,但是Scala  中有没有相应的库函数,由于本人是新手,所以弄了半天,好不容易才将网上的一段Scala 递归获取指定目录下所有目录的代码改成获取文件名,特在此备忘,也希望高手指点. 下面是一段递归获取目录名称的代码: def subdirs(dir: File): Iterator[File] = { val children = dir.listFiles.filter(_.isDirectory) children.toIterator

iOS下载图片之前获取网络图片尺寸的失败尝试

最近一直在找获取网络图片的size的方式,最后得出两个结论: 1 使用分线程下载下来,然后获得图片的size 2 使用网络请求图片的头文件,然后从头文件中找到图片大小的信息 第一种方法需要主线程分线程切换,因为在使用tableView来reloadData的时候,刷表老是出问题,先放着不管 然后我重点是想搞一下第二个方法: 在网上找到了一个博客:http://cxjwin.github.io/2013/11/05/preview_image_size/ 大神写的很不错 主要思路就是先在网上找一个

纯JAVA环境获取APK信息(包名,版本,版本号,大小,权限...),纯JAVA语言编写PC端获取APK信息

纯JAVA环境获取APK信息:包名,版本,版本号,大小,权限... 纯Java环境获取APK信息需要两个包:AXMLPrinter2.jar 跟jdom.jar,用于反编译XML和解析XML的 项目目录 这个类是获取APK信息的 public class ApkUtil { private static final Namespace NS = Namespace.getNamespace("http://schemas.android.com/apk/res/android"); @

PHP获取IP地址

获取客户端IP地址:: function getIp(){ if(!empty($_SERVER['HTTP_CLIENT_IP'])){ return $_SERVER['HTTP_CLIENT_IP']; }elseif(!empty($_SERVER['HTTP_X_FORVARDED_FOR'])){ return $_SERVER['HTTP_X_FORVARDED_FOR']; }elseif(!empty($_SERVER['REMOTE_ADDR'])){ return $_SE