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. Jenkins搭建.NET自动编译发布本地环境

    最近在做一个团队项目的时候,用到了自动编译发布部署环境[也可以说是持续集成],于是顺便学习了下这个环境的搭建过程. 持续集成 持续集成是一种软件开发实践,即团队开发成员经常集成它们的工作,通常每个成员 ...

  2. test20181020 B君的第二题

    题意 分析 考场70分 一看就是裸的kmp,直接打上去. #include<cstdlib> #include<cstdio> #include<cmath> #i ...

  3. mongodb启用Profiling定位问题

    建议使用方法三,最简单且容易查看 一:如果mongodb已经运行了很长时间,此时查看mongod.log很大,没法打开查看相应信息 #ps -ef|grep mongod 找到相应的mongod的进程 ...

  4. k8s PersistentVolume hostpath 简单使用

    kubernets host PersistentVolume 测试 因为yaml 格式的问题 ,我修改为了json 创建 pv pv.json { "kind": "P ...

  5. 文档内容类似项处理-Shingling

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/jituotianxia2009/article/details/25339807 集合的Jaccar ...

  6. 对widget使用WM_SetCallback

    当我们对widget使用WM_SetCallback拦截并处理一些消息,可能需要在处理完某些消息后继续调用该Widget原来的callback,典型的例子是WM_DELETE,因为几乎所有widget ...

  7. java web 程序---留言板

    思路:一个form表单,用户提交留言 一个页面显示留言内容.用到Vector来存取信息并显示 cas.jsp <body> <form action="fei.jsp&qu ...

  8. C++ 构造函数_内存分区_对象初始化

    内存分区 栈区:int  x = 0:int  *p = NULL; 定义一个变量,定义一个指针时,会在栈区进行分配内存.分配的内存系统分配收回的,我们不用管. 堆区:int  *p = new  i ...

  9. MVC confirm提示

    //审核不同意 $("#shbtg").click(function () { $.messager.confirm("提示", "不通过则会被删除, ...

  10. 精《Linux内核精髓:精通Linux内核必会的75个绝技》一HACK #5 使用checkpatch.pl检查补丁的格式

    HACK #5 使用checkpatch.pl检查补丁的格式 本节介绍发布前检查补丁格式的方法.Linux内核是由多个开发者进行开发的.因此,为了保持补丁评估与源代码的可读性,按照统一的规则进行编写是 ...