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 -*-
from PyQt4 import QtCore, QtGui
   
try:
    _fromUtf8 = QtCore.QString.fromUtf8
except AttributeError:
    def _fromUtf8(s):
        return s
   
try:
    _encoding = QtGui.QApplication.UnicodeUTF8
    def _translate(context, text, disambig):
        return QtGui.QApplication.translate(context, text, disambig, _encoding)
except AttributeError:
    def _translate(context, text, disambig):
        return QtGui.QApplication.translate(context, text, disambig)
   
class Ui_Form(object):
    def setupUi(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)
   
    def retranslateUi(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
   
import sys
import os
import time
import httplib
import re
from PyQt4 import QtCore, QtGui
from threading import Thread
   
from find_ui import Ui_Form
   
   
class MyForm(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"
           # if not os.path.isfile(filePath):
            #    print 'aaa'             
             #   return 0
                  
            fileAddress=file(filePath,"r")
            for address_line in fileAddress.readlines():
                if address_line not in addresslist:
                    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)
            for oneAddress in addresslist:
                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" in result or "Forbidden" in result:
                    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 as e:
            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 as e:
            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程序-乾颐堂的更多相关文章

  1. Python使用wxPython、py2exe编写桌面程序-乾颐堂

    Python是支持可视化编程,即编写gui程序,你可以用它来编写自己喜欢的桌面程序.使用wxPython来做界面非常的简单,只是不能像C#一样拖动控件,需要自行写代码布局.在完成编写之后,由于直接的p ...

  2. Python创建单例模式的5种常用方法-乾颐堂

    所谓单例,是指一个类的实例从始至终只能被创建一次. 方法1 如果想使得某个类从始至终最多只有一个实例,使用__new__方法会很简单.Python中类是通过__new__来创建实例的: 1 2 3 4 ...

  3. Python监控日志程序-乾颐堂

    一个简易的日志监控的脚本,功能如下:1.windows环境2.当匹配日志关键字时会发出声音,匹配的关键字不同,播放的声音不同3.能做到实时响应 注意:是在win环境下哦 直接上代码吧 1 2 3 4 ...

  4. python用sqlite3模块操作sqlite数据库-乾颐堂

    SQLite是一个包含在C库中的轻量级数据库.它并不需要独立的维护进程,并且允许使用非标准变体(nonstandard variant)的SQL查询语句来访问数据库. 一些应用可是使用SQLite保存 ...

  5. python生成验证码,文字转换为图片-乾颐堂

    在58或者赶集等一些网站上经常看到手机号是图片格式,或者一些网站的验证码.这些都是动态生成的,今天我们来看一下如何用python把文字生成图片.其实今天主要借助pygame的图像渲染模块,这样比较简单 ...

  6. python移除系统多余大文件-乾颐堂

    文件多了乱放, 突然有一天发现硬盘空间不够了, 于是写了个python脚本搜索所有大于10MB的文件,看看这些大文件有没有重复的副本,如果有,全部列出,以便手工删除 使用方式 加一个指定目录的参数 比 ...

  7. python实现高效率的排列组合算法-乾颐堂

    组合算法 本程序的思路是开一个数组,其下标表示1到m个数,数组元素的值为1表示其下标 代表的数被选中,为0则没选中. 首先初始化,将数组前n个元素置1,表示第一个组合为前n个数. 然后从左到右扫描数组 ...

  8. Python 执行js的2种解决方案-乾颐堂

    第1种方案 SpiderMonkey是Mozilla项目的一部分,是一个用C语言实现的JavaScript脚本引擎, 该引擎分析.编译和执行脚本,根据JS数据类型和对象的需要进行内存分配及释放操作:利 ...

  9. Python图像处理库:Pillow 初级教程-乾颐堂

    Image类 Pillow中最重要的类就是Image,该类存在于同名的模块中.可以通过以下几种方式实例化:从文件中读取图片,处理其他图片得到,或者直接创建一个图片. 使用Image模块中的open函数 ...

随机推荐

  1. NET Core的代码安全分析工具 - Security Code Scan

    NET Core的代码安全分析工具 - Security Code Scan https://www.cnblogs.com/edisonchou/p/edc_security_code_scan_s ...

  2. python(五):面向对象--类和实例

    一.类的基本概念 类是用来创建数据结构和新类型对象的主要机制.一个类定义了一系列与其实例对象密切关联的属性.典型的属性包括变量(也被称为 类变量)和函数(又被称为方法). 1.class上下文 cla ...

  3. RabbitMQ核心概念

    AMQP的四个主要概念 1.虚拟主机(virtual host)或(vhost) 2.交换机(exchange) 3.队列(queue) 4.绑定器(bind) 什么是虚拟主机? 一组交换机.队列和绑 ...

  4. 详解Oracle手动创建数据库几大步骤

    在这里我们将介绍Oracle手动创建数据库几大步骤,包括前期的准备工作,以及具体的实施. Oracle手动创建数据库是本文介绍的重点,希望通过本文能帮助大家更好的利用Oracle.51CTO也向您推荐 ...

  5. IDEA java开发学习笔记

    JDK8下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 配置环境变量 ...

  6. JAVA面向对象编程课程设计——web版斗地主

    一.团队课程设计博客链接 JAVA面向对象编程课程设计--网络版单机斗地主 二.个人负责模块或任务说明 实体类的设计 斗地主规则的实现 人机自动出牌的算法 实现数据库的DAO模式 三.自己的代码提交记 ...

  7. CFGym 101158B(巨坑题)

    前言:无话可说,看懂题意就没什么难度了. 题意:对于[0, 9999]区间内的每一个数b,通过输入的转换表,得到一个e值,把这个值添加到b的后面,得到一个五位数c.对于c的每一位,从0枚举到9,得到5 ...

  8. C++客户端通过gSOAP调用WebService

    webService三要素: SOAP(Simple Object Access Protocol).WSDL(WebServicesDescriptionLanguage).UDDI(Univers ...

  9. Unity3D的坑系列:动态加载dll

    我现在参与的项目是做MMO手游,目标平台是Android和iOS,iOS平台不能动态加载dll(什么原因找乔布斯去),可以直接忽略,而在Android平台是可以动态加载dll的,有了这个就可以实现代码 ...

  10. [Python] numpy.ndarray.shape

    ndarray.shape Tuple of array dimensions. x = np.array([1, 2, 3, 4]) print x.shape #(4, ) y = np.zero ...