Adobe Reader – Escape From ‘.PDF’ Execute Embedded Executable

  • 作者: Didier Stevens
    日期: 2010-03-31
  • 类别:
    平台:
  • 来源:https://www.exploit-db.com/exploits/11987/
  • Title	: Escape From PDF
    Author	: Didier Stevens
    Date	: 03/29/2010
    Source	: http://blog.didierstevens.com/2010/03/29/escape-from-pdf/
    
    This is a special PDF hack: I managed to make a PoC PDF to execute an embedded executable without exploiting any vulnerability!
    
    I use a launch action triggered by the opening of my PoC PDF. With Adobe Reader, the user gets a warning asking for approval to launch the action, but I can (partially) control the message displayed by the dialog. Foxit Reader displays no warning at all, the action gets executed without user interaction.
    
    PDF viewers like Adobe Reader and Foxit Reader don’t allow embedded executables (like binaries and scripts) to be extracted and executed, but I found another way to launch a command (/Launch /Action), and ultimately run an executable I embedded using a special technique. With Adobe Reader, a launch action needs to be approved by the user, but I can partially control the message displayed by the dialog box.
    
    	Example 1:
    	http://didierstevens.files.wordpress.com/2010/03/20100329-211248.png?w=478&h=262
    
    	Example 2:
    	http://didierstevens.files.wordpress.com/2010/03/20100329-211313.png?w=478&h=262
    
    Do you believe this could this mislead some of your users? Or maybe you can come up with a better message to fool your users.
    
    With Foxit Reader, no warning is displayed:
    
    	Example 3:
    	http://didierstevens.files.wordpress.com/2010/03/20100329-211310.png?w=457&h=385
    
    I’m not publishing my PoC PDF yet, but you can download a PDF that will just launch cmd.exe here. Use it to test your PDF reader:
    
    	https://gitlab.com/exploit-database/exploitdb-bin-sploits/-/raw/main/bin-sploits/11987.zip (launch-action-cmd.zip)
    
    With Adobe Reader, the only thing preventing execution is a warning. Disabling JavaScript will not prevent this (I don’t use JavaScript in my PoC PDF), and patching Adobe Reader isn’t possible (I’m not exploiting a vulnerability, just being creative with the PDF language specs).
    
    I shared my PoC with Adobe’s PSIRT. Maybe they will come up with a solution to prevent this, should they consider that the protection offered by the warning dialog is not sufficient. BTW, preventing Adobe Reader from creating new processes blocks this trick.
    
    n this case, Foxit Reader is probably worse than Adobe Reader, because no warning gets displayed to prevent the launch action. My PoC PDF requires some changes for Foxit Reader, because ultimately, the executable doesn’t run. But that’s probably due to some variation in the PDF language supported by Foxit Reader.
    
    Tested with Adobe Reader 9.3.1 on Windows XP SP3 and Windows 7.