python 探测网站目录的GUI程序-乾颐堂
1.pyqt4写的界面 find_ui.py
| 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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 | #-*- coding: utf-8 -*- fromPyQt4 importQtCore, QtGui   try:     _fromUtf8 =QtCore.QString.fromUtf8 exceptAttributeError:     def_fromUtf8(s):         returns   try:     _encoding =QtGui.QApplication.UnicodeUTF8     def_translate(context, text, disambig):         returnQtGui.QApplication.translate(context, text, disambig, _encoding) exceptAttributeError:     def_translate(context, text, disambig):         returnQtGui.QApplication.translate(context, text, disambig)   classUi_Form(object):     defsetupUi(self, Form):         Form.setObjectName(_fromUtf8("Form"))         Form.resize(516, 467)         self.label =QtGui.QLabel(Form)         self.label.setGeometry(QtCore.QRect(20, 10, 54, 16))         self.label.setObjectName(_fromUtf8("label"))         self.edit_address =QtGui.QLineEdit(Form)         self.edit_address.setGeometry(QtCore.QRect(80, 10, 351, 20))         self.edit_address.setObjectName(_fromUtf8("edit_address"))         self.button_search =QtGui.QPushButton(Form)         self.button_search.setGeometry(QtCore.QRect(440, 10, 61, 23))         self.button_search.setObjectName(_fromUtf8("button_search"))         self.text_all =QtGui.QTextEdit(Form)         self.text_all.setGeometry(QtCore.QRect(20, 40, 411, 261))         self.text_all.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOff)         self.text_all.setObjectName(_fromUtf8("text_all"))         self.label_2 =QtGui.QLabel(Form)         self.label_2.setGeometry(QtCore.QRect(20, 320, 54, 12))         self.label_2.setObjectName(_fromUtf8("label_2"))         self.text_exist =QtGui.QTextEdit(Form)         self.text_exist.setGeometry(QtCore.QRect(20, 340, 411, 64))         self.text_exist.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOff)         self.text_exist.setObjectName(_fromUtf8("text_exist"))         self.label_3 =QtGui.QLabel(Form)         self.label_3.setGeometry(QtCore.QRect(380, 310, 91, 20))         self.label_3.setText(_fromUtf8(""))         self.label_3.setObjectName(_fromUtf8("label_3"))         self.edit_add =QtGui.QLineEdit(Form)         self.edit_add.setGeometry(QtCore.QRect(20, 420, 411, 20))         self.edit_add.setObjectName(_fromUtf8("edit_add"))         self.button_add =QtGui.QPushButton(Form)         self.button_add.setGeometry(QtCore.QRect(440, 420, 71, 23))         self.button_add.setObjectName(_fromUtf8("button_add"))         self.label_4 =QtGui.QLabel(Form)         self.label_4.setGeometry(QtCore.QRect(20, 440, 251, 16))         self.label_4.setObjectName(_fromUtf8("label_4"))           self.retranslateUi(Form)         QtCore.QMetaObject.connectSlotsByName(Form)       defretranslateUi(self, Form):         Form.setWindowTitle(_translate("Form", "目录探测工具", None))         self.label.setText(_translate("Form", "网站地址:", None))         self.button_search.setText(_translate("Form", "探测", None))         self.label_2.setText(_translate("Form", "结果:", None))         self.button_add.setText(_translate("Form", "添加地址", None))         self.label_4.setText(_translate("Form", "例如:/admin/manager.asp  请以斜杠开始", None)) | 
2. 启动文件 start.py
| 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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | #!/usr/local/bin/python #coding=utf-8  importsys importos importtime importhttplib importre from PyQt4 importQtCore, QtGui from threading importThread   from find_ui importUi_Form     classMyForm(QtGui.QMainWindow):     def __init__(self, parent=None):         QtGui.QWidget.__init__(self, parent)         self.ui = Ui_Form()         self.ui.setupUi(self)         QtCore.QObject.connect(self.ui.button_search,QtCore.SIGNAL("clicked()"), self.startthread)         QtCore.QObject.connect(self.ui.button_add,QtCore.SIGNAL("clicked()"), self.addAddress)     def startSearch(self):         self.ui.label_3.setText("")          self.getAddress()         address=str(self.ui.edit_address.text())         self.accessAddesss(address)               def startthread(self):         t1=Thread(target=self.startSearch,)         t1.start()                         def getAddress(self):         try:             global addresslist             addresslist=[]             filePath=os.getcwd()+"\\address.txt"           # ifnot os.path.isfile(filePath):             #    print 'aaa'             #   return0                             fileAddress=file(filePath,"r")             foraddress_line infileAddress.readlines():                 ifaddress_line not inaddresslist:                     addresslist.append(address_line)                     pass                 pass             pass             fileAddress.close()                       except:             #self.ui.text_all.setText('aaa')             self.ui.text_all.setText(u'打开文件错误')             pass         finally:             #fileAddress.close()             pass        # print addresslist[0]           def accessAddesss(self,host):         try:             print host             print len(addresslist)             foroneAddress inaddresslist:                 print len(addresslist)                 oneAddress=oneAddress.replace("\n","")                 print oneAddress                 connection=httplib.HTTPConnection(host,80,timeout=10)                 connection.request("GET",oneAddress)                 response=connection.getresponse()                 result=response.reason                 resultNum=response.status                                   if"OK"inresult or "Forbidden"inresult:                     getaddress="http://"+host+oneAddress+"------"+str(resultNum)+":"+result                     self.ui.text_exist.append(getaddress)                 else:                     self.ui.text_all.append("http://"+host+oneAddress+"------"+str(resultNum)+":"+result)                                       connection.close()         except Exception ase:             print e.message         self.ui.label_3.setText(u"探测完成")          self.ui.label_3.colorCount()              def  addAddress(self):         try:             filePath=os.getcwd()+"\\address.txt"            fileAddress=file(filePath,"a")             newAddress="\n"+str(self.ui.edit_add.text())             print newAddress             fileAddress.write(newAddress)             fileAddress.close()         except Exception ase:             print e.message             if__name__ == "__main__":     app = QtGui.QApplication(sys.argv)     myapp = MyForm()     myapp.show()     sys.exit(app.exec_()) | 
3.address.txt 扫描地址名单文件,可以通过编辑改文件制定自己的规则,你懂的~~
/admin.php
/admin/
/administrator/
/moderator/
/webadmin/
/adminarea/
/bb-admin/
/adminLogin/
/test/login.jsp
/source/login.php
www.qytang.com/
http://www.qytang.com/cn/list/29/
http://www.qytang.com/cn/list/28/404.htm
http://www.qytang.com/cn/list/28/397.htm
http://www.qytang.com/cn/list/28/396.htm
http://www.qytang.com/cn/list/28/395.htm
http://www.qytang.com/cn/list/28/394.htm
http://www.qytang.com/cn/list/28/393.htm
http://www.qytang.com/cn/list/28/391.htm
http://www.qytang.com/cn/list/28/389.htm
http://www.qytang.com/cn/list/28/388.htm
http://www.qytang.com/cn/list/28/362.htm
http://www.qytang.com/cn/list/28/358.htm
http://www.qytang.com/cn/list/28/351.htm
http://www.qytang.com/cn/list/28/348.htm
http://www.qytang.com/cn/list/28/340.htm
http://www.qytang.com/cn/list/28/338.htm
http://www.qytang.com/cn/list/28/336.htm
http://www.qytang.com/cn/list/28/330.htm
python 探测网站目录的GUI程序-乾颐堂的更多相关文章
- Python使用wxPython、py2exe编写桌面程序-乾颐堂
		Python是支持可视化编程,即编写gui程序,你可以用它来编写自己喜欢的桌面程序.使用wxPython来做界面非常的简单,只是不能像C#一样拖动控件,需要自行写代码布局.在完成编写之后,由于直接的p ... 
- Python创建单例模式的5种常用方法-乾颐堂
		所谓单例,是指一个类的实例从始至终只能被创建一次. 方法1 如果想使得某个类从始至终最多只有一个实例,使用__new__方法会很简单.Python中类是通过__new__来创建实例的: 1 2 3 4 ... 
- Python监控日志程序-乾颐堂
		一个简易的日志监控的脚本,功能如下:1.windows环境2.当匹配日志关键字时会发出声音,匹配的关键字不同,播放的声音不同3.能做到实时响应 注意:是在win环境下哦 直接上代码吧 1 2 3 4 ... 
- python用sqlite3模块操作sqlite数据库-乾颐堂
		SQLite是一个包含在C库中的轻量级数据库.它并不需要独立的维护进程,并且允许使用非标准变体(nonstandard variant)的SQL查询语句来访问数据库. 一些应用可是使用SQLite保存 ... 
- python生成验证码,文字转换为图片-乾颐堂
		在58或者赶集等一些网站上经常看到手机号是图片格式,或者一些网站的验证码.这些都是动态生成的,今天我们来看一下如何用python把文字生成图片.其实今天主要借助pygame的图像渲染模块,这样比较简单 ... 
- python移除系统多余大文件-乾颐堂
		文件多了乱放, 突然有一天发现硬盘空间不够了, 于是写了个python脚本搜索所有大于10MB的文件,看看这些大文件有没有重复的副本,如果有,全部列出,以便手工删除 使用方式 加一个指定目录的参数 比 ... 
- python实现高效率的排列组合算法-乾颐堂
		组合算法 本程序的思路是开一个数组,其下标表示1到m个数,数组元素的值为1表示其下标 代表的数被选中,为0则没选中. 首先初始化,将数组前n个元素置1,表示第一个组合为前n个数. 然后从左到右扫描数组 ... 
- Python 执行js的2种解决方案-乾颐堂
		第1种方案 SpiderMonkey是Mozilla项目的一部分,是一个用C语言实现的JavaScript脚本引擎, 该引擎分析.编译和执行脚本,根据JS数据类型和对象的需要进行内存分配及释放操作:利 ... 
- Python图像处理库:Pillow 初级教程-乾颐堂
		Image类 Pillow中最重要的类就是Image,该类存在于同名的模块中.可以通过以下几种方式实例化:从文件中读取图片,处理其他图片得到,或者直接创建一个图片. 使用Image模块中的open函数 ... 
随机推荐
- NET Core的代码安全分析工具 - Security Code Scan
			NET Core的代码安全分析工具 - Security Code Scan https://www.cnblogs.com/edisonchou/p/edc_security_code_scan_s ... 
- python(五):面向对象--类和实例
			一.类的基本概念 类是用来创建数据结构和新类型对象的主要机制.一个类定义了一系列与其实例对象密切关联的属性.典型的属性包括变量(也被称为 类变量)和函数(又被称为方法). 1.class上下文 cla ... 
- RabbitMQ核心概念
			AMQP的四个主要概念 1.虚拟主机(virtual host)或(vhost) 2.交换机(exchange) 3.队列(queue) 4.绑定器(bind) 什么是虚拟主机? 一组交换机.队列和绑 ... 
- 详解Oracle手动创建数据库几大步骤
			在这里我们将介绍Oracle手动创建数据库几大步骤,包括前期的准备工作,以及具体的实施. Oracle手动创建数据库是本文介绍的重点,希望通过本文能帮助大家更好的利用Oracle.51CTO也向您推荐 ... 
- IDEA java开发学习笔记
			JDK8下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 配置环境变量 ... 
- JAVA面向对象编程课程设计——web版斗地主
			一.团队课程设计博客链接 JAVA面向对象编程课程设计--网络版单机斗地主 二.个人负责模块或任务说明 实体类的设计 斗地主规则的实现 人机自动出牌的算法 实现数据库的DAO模式 三.自己的代码提交记 ... 
- CFGym 101158B(巨坑题)
			前言:无话可说,看懂题意就没什么难度了. 题意:对于[0, 9999]区间内的每一个数b,通过输入的转换表,得到一个e值,把这个值添加到b的后面,得到一个五位数c.对于c的每一位,从0枚举到9,得到5 ... 
- C++客户端通过gSOAP调用WebService
			webService三要素: SOAP(Simple Object Access Protocol).WSDL(WebServicesDescriptionLanguage).UDDI(Univers ... 
- Unity3D的坑系列:动态加载dll
			我现在参与的项目是做MMO手游,目标平台是Android和iOS,iOS平台不能动态加载dll(什么原因找乔布斯去),可以直接忽略,而在Android平台是可以动态加载dll的,有了这个就可以实现代码 ... 
- [Python] numpy.ndarray.shape
			ndarray.shape Tuple of array dimensions. x = np.array([1, 2, 3, 4]) print x.shape #(4, ) y = np.zero ... 
