码迷,mamicode.com
首页 > 编程语言 > 详细

【python】POST上传APK检测是否存在ZipperDown漏洞

时间:2018-08-08 21:19:25      阅读:314      评论:0      收藏:0      [点我收藏+]

标签:hex   int   android   文件名   try   urllib   exce   web   上传   

前言

用POST的方式上传文件,检测APK是否存在ZipperDown漏洞。

代码


#  authour:zzzhhh
#  2018.08.08
#  check ZipperDown

# -*- coding: utf-8 -*-
from selenium import webdriver
import os
import time
import urllib2
import base64
import json


def post_upload(file_path):

    file_size = os.path.getsize(file_path)    # 获取文件大小
    filename = os.path.basename(file_path)    # 获取文件名

    boundary = ‘----------%s‘ % "WebKitFormBoundar"+base64.b64encode(hex(int(time.time() * 1000))).rstrip(‘=‘)
    data = []
    data.append(‘--%s‘ % boundary)

    data.append(‘Content-Disposition: form-data; name="%s"\r\n‘ % ‘id‘)
    data.append(‘WU_FILE_0‘)
    data.append(‘--%s‘ % boundary)
    data.append(‘Content-Disposition: form-data; name="%s"\r\n‘ % ‘name‘)
    data.append("%s" % filename)
    data.append(‘--%s‘ % boundary)
    data.append(‘Content-Disposition: form-data; name="%s"\r\n‘ % ‘type‘)
    data.append(‘application/vnd.android.package-archive‘)
    data.append(‘--%s‘ % boundary)
    data.append(‘Content-Disposition: form-data; name="%s"\r\n‘ % ‘lastModifiedDate‘)
    data.append(‘Sat Apr 12 2014 05:07:04 GMT+0800 (涓浗鏍囧噯鏃堕棿)‘)
    data.append(‘--%s‘ % boundary)
    data.append(‘Content-Disposition: form-data; name="%s"\r\n‘ % ‘size‘)
    data.append("%s" % file_size)    #文件大小
    data.append(‘--%s‘ % boundary)


    fr = open(filename, ‘rb‘)
    data.append(‘Content-Disposition: form-data; name="file"; filename="%s"‘ % filename)
    data.append(‘Content-Type: %s\r\n‘ % ‘application/vnd.android.package-archive‘)
    data.append(fr.read())
    fr.close()
    data.append(‘--%s--\r\n‘ % boundary)

    http_url = ‘http://appscan.360.cn/app/upload_zipperdown/‘
    http_body = ‘\r\n‘.join(data)
    try:
        # buld http request
        req = urllib2.Request(http_url, data=http_body)
        # header
        req.add_header(‘Content-Type‘, ‘multipart/form-data; boundary=%s‘ % boundary)
        req.add_header(‘User-Agent‘, ‘Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36‘)
        req.add_header(‘Referer‘, ‘http://appscan.360.cn/tool/‘)
        # post data to server
        resp = urllib2.urlopen(req, timeout=5)
        # get response
        qrcont = resp.read()
        print qrcont
        return qrcont
    except Exception, e:
        print ‘http error‘



if __name__ == ‘__main__‘:
    file_path = os.getcwd() +"\\1.apk"
    res = post_upload(file_path)
    setting = json.loads(res)
    print ‘http://appscan.360.cn/‘+setting[‘result‘]

【python】POST上传APK检测是否存在ZipperDown漏洞

标签:hex   int   android   文件名   try   urllib   exce   web   上传   

原文地址:https://www.cnblogs.com/17bdw/p/9445403.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!