python自动化邮件管理(Python实现E-Mail收集插件实例教程)
python自动化邮件管理
Python实现E-Mail收集插件实例教程__import__函数
我们都知道import是导入模块的,但是其实import实际上是使用builtin函数import来工作的。在一些程序中,我们可以动态去调用函数,如果我们知道模块的名称(字符串)的时候,我们可以很方便的使用动态调用
|
def getfunctionbyname(module_name, function_name): module = __import__ (module_name) return getattr (module, function_name) |
通过这段代码,我们就可以简单调用一个模块的函数了
插件系统开发流程
一个插件系统运转工作,主要进行以下几个方面的操作
- 获取插件,通过对一个目录里的.py文件扫描得到
- 将插件目录加入到环境变量sys.path
- 爬虫将扫描好的 url 和网页源码传递给插件
- 插件工作,工作完毕后将主动权还给扫描器
插件系统代码
在lib/core/plugin.py中创建一个spiderplus类,实现满足我们要求的代码
|
# __author__ = 'mathor' import os import sys class spiderplus( object ): def __init__( self , plugin, disallow = []): self .dir_exploit = [] self .disallow = [ '__init__' ] self .disallow.extend(disallow) self .plugin = os.getcwd() + '/' + plugin sys.path.append(plugin) def list_plusg( self ): def filter_func( file ): if not file .endswith( '.py' ): return false for disfile in self .disallow: if disfile in file : return false return true dir_exploit = filter (filter_func, os.listdir( self .plugin) return list (dir_exploit) def work( self , url, html): for _plugin in self .list_plusg(): try : m = __import__ (_plugin.split( '.' )[ 0 ]) spider = getattr (m, 'spider' ) p = spider() s = p.run(url, html) except exception as e: print (e) |
work函数中需要传递 url,html,这个就是我们扫描器传给插件系统的,通过代码
|
spider = getattr (m, 'spider' ) p = spider() s = p.run(url, html) |
我们定义插件必须使用class spider中的run方法调用
扫描器中调用插件
我们主要用爬虫调用插件,因为插件需要传递 url 和网页源码这两个参数,所以我们在爬虫获取到这两个的地方加入插件系统代码即可
首先打开spider.py,在spider.py文件开头加上
|
from lib.core import plugin |
然后在文件的末尾加上
|
disallow = [ 'sqlcheck' ] _plugin = plugin.spiderplus( 'script' , disallow) _plugin.work(_str[ 'url' ], _str[ 'html' ]) |
disallow是不允许的插件列表,为了方便测试,我们可以把 sqlcheck 填上
sql 注入融入插件系统
其实非常简单,只需要修改script/sqlcheck.py为下面即可
关于download模块,其实就是downloader模块,把downloader.py复制一份命名为download.py就行
|
import re, random from lib.core import download class spider: def run( self , url, html): if ( not url.find( "?" )): # pseudo-static page return false; downloader = download.downloader() boolean_tests = ( " and %d=%d" , " or not (%d=%d)" ) dbms_errors = { # regular expressions used for dbms recognition based on error message response "mysql" : (r "sql syntax.*mysql" , r "warning.*mysql_.*" , r "valid mysql result" , r "mysqlclient\." ), "postgresql" : (r "postgresql.*error" , r "warning.*\wpg_.*" , r "valid postgresql result" , r "npgsql\." ), "microsoft sql server" : (r "driver.* sql[\-\_\ ]*server" , r "ole db.* sql server" , r "(\w|\a)sql server.*driver" , r "warning.*mssql_.*" , r "(\w|\a)sql server.*[0-9a-fa-f]{8}" , r "(?s)exception.*\wsystem\.data\.sqlclient\." , r "(?s)exception.*\wroadhouse\.cms\." ), "microsoft access" : (r "microsoft access driver" , r "jet database engine" , r "access database engine" ), "oracle" : (r "\bora-[0-9][0-9][0-9][0-9]" , r "oracle error" , r "oracle.*driver" , r "warning.*\woci_.*" , r "warning.*\wora_.*" ), "ibm db2" : (r "cli driver.*db2" , r "db2 sql error" , r "\bdb2_\w+\(" ), "sqlite" : (r "sqlite/jdbcdriver" , r "sqlite.exception" , r "system.data.sqlite.sqliteexception" , r "warning.*sqlite_.*" , r "warning.*sqlite3::" , r "\[sqlite_error\]" ), "sybase" : (r "(?i)warning.*sybase.*" , r "sybase message" , r "sybase.*server message.*" ), } _url = url + "%29%28%22%27" _content = downloader.get(_url) for (dbms, regex) in ((dbms, regex) for dbms in dbms_errors for regex in dbms_errors[dbms]): if (re.search(regex,_content)): return true content = {} content[ 'origin' ] = downloader.get(_url) for test_payload in boolean_tests: # right page randint = random.randint( 1 , 255 ) _url = url + test_payload % (randint, randint) content[ "true" ] = downloader.get(_url) _url = url + test_payload % (randint, randint + 1 ) content[ "false" ] = downloader.get(_url) if content[ "origin" ] = = content[ "true" ] ! = content[ "false" ]: return "sql found: %" % url |
e-mail 搜索插件
最后一个简单的例子,搜索网页中的 e-mail,因为插件系统会传递网页源码,我们用一个正则表达式([\w-]+@[\w-]+\.[\w-]+)+搜索出所有的邮件。创建script/email_check.py文件
# __author__ = 'mathor'
|
import re class spider(): def run( self , url, html): #print(html) pattern = re. compile (r '([\w-]+@[\w-]+\.[\w-]+)+' ) email_list = re.findall(pattern, html) if (email_list): print (email_list) return true return false |
运行python w8ay.py
可以看到网页中的邮箱都被采集到了
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对开心学习网的支持。
原文链接:https://www.wmathor.com/index.php/archives/1193/
- python sql注入怎么避免(Python实现SQL注入检测插件实例代码)
- chrome适合开发的插件(Chrome插件扩展开发全攻略完整demo)
- 宝塔面板一键部署教程(使用宝塔面板负载均衡插件的心得和解决的方法)
- Visual studio中使用VSCommands插件在大括号尾部显示方法或过程名字
- vue.js 怎么做插件(Vue.js实现音乐播放器)
- sublime text 安装package control,方便其它插件安装
- vue表单上传图片数据(vue-cropper插件实现图片截取上传组件封装)
- html5 canvas 性能(基于html5 canvas做批改作业的小插件)
- idea连接不上docker(IDEA使用Docker插件远程部署项目到云服务器的方法步骤)
- html5菜单栏(html5写一个BUI折叠菜单插件的实现方法)
- python自动化邮件管理(Python实现E-Mail收集插件实例教程)
- vuejs组件使用教程交流(Vue vee-validate插件的简单使用)
- jquery插件写法
- dede裁剪插件(DEDE在图集列表中调出图集的所有图片)
- dedecms缩略图插件(织梦DEDECMS有缩略图显示,没有显示随机指定图片的实现方法)
- python3循环使用教程(Python3.4学习笔记之 idle 清屏扩展插件用法分析)
- 今年考高会很难吗(今年高考会考试吗)
- 盘古开天地 他创造了世界,谁创造了盘古 盘古是伏羲吗(盘古开天地他创造了世界)
- 关于队徽 你了解这些么 二(关于队徽你了解这些么)
- 冬天来了手脚冰凉 真不是因为上辈子你是折翼的天使(冬天来了手脚冰凉)
- 0 1 岁婴儿最强作息指南,照着做养出天使宝宝(01岁婴儿最强作息指南)
- 沪上这16所高校 萌新 礼包开箱 哪一款让你心动(沪上这16所高校萌新)
热门推荐
- 日常操作docker命令(SEATA事务服务DOCKER部署的过程详解)
- h5制作支付功能(基于HTML5+tracking.js实现刷脸支付功能)
- python中for语句的无限循环(python使用for循环计算0-100的整数的和方法)
- docker redis配置文件放哪里(最详细的docker中安装并配置redis图文详解)
- vscode如何配置python环境(VSCode Python开发环境配置的详细步骤)
- 织梦cms指定栏目怎么取(织梦CMS后台模板列表按字母排序方法)
- sqlserver常用配置调整(sql server性能调优 I/O开销的深入解析)
- java集成钉钉发送消息(Python实现钉钉发送报警消息的方法)
- dedecms标签怎么调用(dedecms网站栏目增加缩略图的方法)
- xm文档使用教程(xmapp环境搭建注意事项说明)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9