Windows PrintDemonÌáȨ·ì϶·ÖÎö

°ä²¼¹¦·ò 2020-05-21

1.·ì϶¸ÅÊö


΢ÈíÔÚ5ÔÂ12Èյݲȫ¸üÐÂÖй«¿ªÁËÒ»¸öWindows±¾µØÌáÈ¡·ì϶£¨CVE-2020-1048£©£¬£¬ £¬¸Ã·ì϶µÄÃèÊöΪ£º

¡°Windows Print Spooler·þÎñ²»Ç¡±¾µØÔÊÐíËÁÒâµÄÎļþϵͳдÈ룬£¬ £¬´æÔÚÌØÈ¨ÌáÉý·ì϶¡£¹¥»÷ÕßÀûÓô˷ì϶¿ÉÄÜÓÃÏµÍ³ÌØÈ¨ÔËÐÐËÁÒâ´úÂ룬£¬ £¬´Ó¶øÊµÏÖ£º·¨Ê½µÄ×°Öᢡ¢¡¢²é¿´¡¢¡¢¡¢¸ü¸Ä»òÊý¾Ýɾ³ý£¬£¬ £¬ÒÔ¼°´´½¨ÓµÓÐÆëȫȨÏÞµÄÕÊ»§¡£ÒªÀûÓô˷ì϶£¬£¬ £¬¹¥»÷Õß±ØÐëµÇ¼µ½ÊÜÓ°ÏìµÄϵͳ²¢ÔËÐÐÌØ¶¨¾ç±¾»òÀûÓ÷¨Ê½¡±¡£


¸Ã·ì϶Óɰ²È«×êÑÐÈËÔ±Alex IonescuºÍYarden Shafir·¢ÏÖ£¬£¬ £¬²¢±»¶¨ÃûΪPrintDemon¡£Print SpoolerÊÇϵͳ×Ô´øµÄ´òÓ¡ºó¶Ü´¦Ö÷þÎñ£¬£¬ £¬ÖÎÀíËùÓб¾µØºÍÍøÂç´òÓ¡¶ÓÁУ¬£¬ £¬½ÚÖÆ×ÅËùÓдòÓ¡¹¤×÷¡£Print SpoolerÔÚWindowsϵͳÖÐÒÑ´æÔÚ¶àÄ꣬£¬ £¬´Ó΢Èí°ä²¼µÄ²¹¶¡Ò³Ãæ¿ÉÖª¸Ã·ì϶ӰÏìWindows7ÖÁWindows10 1909µÄÏÕЩËùÓа汾¡£


2.·ì϶ÑéÖ¤


OG¶«·½ÌüADLab°²È«×êÑÐÔ±¶Ô¸Ã·ì϶½øÐÐÁË·ÖÎöºÍÑéÖ¤£¬£¬ £¬ÊµÏÖÁËÔÚµÍȨÏ޵ij߶ÈÓû§ÏÂдÈëϵͳĿ¼£¬£¬ £¬²âÊÔ²Ù×÷ϵͳΪWindows 10 x64ÆóÒµ°æ2016£¨³Ö¾Ã·þÎñ°æ£©£¬£¬ £¬²âÊÔ²½ÖèÈçÏ£º


£¨1£©ÔÚ²âÊÔϵͳÖд´½¨Ò»¸ö³ß¶ÈÓû§test£¬£¬ £¬²¢Ê¹Óøó߶ÈÓû§µÇ¼ϵͳ¡£²é¿´ÆäËùÊôÓû§×飬£¬ £¬È·ÈÏÆä²»ÊÇÖÎÀíÔ±Óû§×é¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


£¨2£©ÔÚtestÕË»§Ï£¬£¬ £¬³¢ÊÔÔÚϵͳĿ¼Ï´´½¨Îļþ¼Ð»òÕßдÈëÎļþ£¬£¬ £¬¾ùʧ°Ü¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


£¨3£©¶øºóÖ´ÐÐÈçÏÂPowerShellºÅÁ£¬ £¬ÒÔÆÚÔÚϵͳĿ¼Ï´´½¨Îļþmyport.txt¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


£¨4£©ÖØÆô²âÊÔϵͳ²¢µÇ¼testÓû§£¬£¬ £¬Äܹ»¿´µ½ÔÚϵͳĿ¼ÏÂÒÑÌìÉúÁËmyport.txtÎļþ£¬£¬ £¬²é¿´ÄÚÈݵÄÈ·Ô̺¬Á˲âÊÔ×Ö·û´®¡£¸ÃÁ˾ÖÅú×¢£ºµÍȨÏÞµÄ testÓû§Í»ÆÆÁËÎÞ·¨Åú¸Äϵͳ×ÊÔ´µÄ°²È«ÏÞ¶È¡£


OG¶«·½Ìü¡¤(Öйú´ó½)

OG¶«·½Ìü¡¤(Öйú´ó½)


3.·ì϶µÀÀí


¸Ã·ìÏ¶Éæ¼°µ½Windows´òÓ¡»úµÄ¹¤×÷»úÖÆ£¬£¬ £¬Îª¸üºÃµÄÀí½â·ì϶³ÉÒò£¬£¬ £¬Ê×Ïȵ¥Ò»½éÉÜ´òÓ¡»ú»ù´¡ÖªÊ¶£¬£¬ £¬¶øºóÔÙ·ÖÎö·ì϶³ÉÒò¡£


´òÓ¡»ú¹¤×÷»úÖÆ


WindowsϵͳµÄ´òÓ¡»úÓÐÁ½¸öÖ÷Ìâ×é¼þ£º´òÓ¡»úÇý¶¯ºÍ´òÓ¡»ú¶Ë¿Ú¡£


¡ö ´òÓ¡»úÇý¶¯

ÔÚÔö³¤Ò»¸ö´òÓ¡»úʱ£¬£¬ £¬±ØÒª×°ÖôòÓ¡»úÇý¶¯¡£ÔÚMSDNÎĵµÃèÊöÖУ¬£¬ £¬ÔçÆÚϵͳҪÇóÖ»Óо߱¸SeLoadDriverPrivilegeȨÏÞµÄÓû§ÄÜÁ¦×°ÖôòÓ¡Çý¶¯£¬£¬ £¬µ«ÎªÁ˱ãÓڳ߶ÈÓû§×°ÖÃÇý¶¯£¬£¬ £¬´ÓWindows VistaÆðÍ·£¬£¬ £¬Ö»ÓдòÓ¡»úÇý¶¯ÊÇÒѾ­´æÔڵĿÉÁ¢¼´±ãÓõÄÇý¶¯£¬£¬ £¬¾Í²»±ØÒªÈκÎÌØÈ¨¼´¿É×°Öá£ÀýÈ磬£¬ £¬Í¨¹ýÒ»ÌõPowerShellºÅÁî¼´¿É×°Öá°Generic / Text-Only¡±Çý¶¯¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


¡ö ´òÓ¡»ú¶Ë¿Ú


ÔÚÔö³¤Ò»¸ö´òÓ¡»úʱ£¬£¬ £¬±ØÒªÉèÖôòÓ¡»úµÄ¶Ë¿Ú¡£WindowsÖ§³Ö¶àÖÖÀàÐ͵ĴòÓ¡»ú¶Ë¿Ú£ºLPT1¶Ë¿Ú¡¢¡¢¡¢USB¶Ë¿Ú¡¢¡¢¡¢ÍøÂç¶Ë¿ÚºÍÎļþµÈ¡£ÈôÊÇÉèÖö˿ÚΪÎļþ£¬£¬ £¬ÔòÒâζ×Å´òÓ¡»ú½«Êý¾Ý´òÓ¡µ½Ö¸¶¨Îļþ¡£ÀýÈ磬£¬ £¬Í¨¹ýÒ»ÌõPowerShellºÅÁî¼´¿ÉÔö³¤Ò»¸öÊä³öµ½Ö¸¶¨ÎļþµÄ´òÓ¡¶Ë¿Ú£º

Add-PrinterPort -Name "C:\windows\Temp\myport.txt"


OG¶«·½Ìü¡¤(Öйú´ó½)


ÏÖʵÉÏ£¬£¬ £¬¸Ã²Ù×÷ÊÇÔÚ×¢²á±íÖÐÔö³¤Ò»¸öREG_SZÀàÐ͵ÄÖµ¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


³ï±¸ºÃÇý¶¯ºÍ¶Ë¿Úºó£¬£¬ £¬Í¨¹ýÒ»ÌõPowerShellºÅÁî¼´¿É´´½¨Ò»¸ö´òÓ¡»ú¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


´òÓ¡»ú´´½¨½áÊøºó£¬£¬ £¬Í¨¹ýÒ»ÌõPowerShellºÅÁî¼´¿É´òÓ¡Êý¾Ýµ½Ö¸¶¨¶Ë¿Ú£º

"PrintTest!" | Out-Printer -Name "PrintTest"


ÓÉÓÚPrintTest´òÓ¡»úµÄ¶Ë¿ÚÊÇÎļþc:\windows\Temp\myport.txt£¬£¬ £¬Òò¶ø´òÓ¡ºÅÁîÖ´Ðк󣬣¬ £¬Êý¾Ý¡°Print Test!¡±½«»á±»Ð´È루¼´´òÓ¡£©µ½¸ÃÎļþ¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


Õë¶Ô¶Ë¿ÚÊÇÎļþµÄ´òÓ¡¹ý³Ì£¬£¬ £¬spooler´òÓ¡·þÎñ·¨Ê½ÒÔimpersonating·½Ê½À´·ÂÕÕµ±Ç°Óû§µÄÌØÈ¨½øÐÐÎļþдÈë¡£Òò¶ø£¬£¬ £¬ÈôÊǶ˿ÚÎļþÔÚÊܱ£»¤µÄϵͳĿ¼£¨ÀýÈçC:\Windows\system32£©£¬£¬ £¬ Ôò·ÇÖÎÀíԱϵÄPowerShell´òÓ¡×÷Òµ¾Í»áʧ°Ü¡£


OG¶«·½Ìü¡¤(Öйú´ó½)

OG¶«·½Ìü¡¤(Öйú´ó½)


ÍÑ»ú´òÓ¡µÄ»úÖÆ


ÔÚWindowsϵͳÉÏ£¬£¬ £¬ÈôÊÇϵͳÅäÖÃÆôÓÃÁ˼ÙÍÑ»ú·þÎñ£¬£¬ £¬ÔòËùÓеĴòÓ¡¹¤×÷¶¼²»ÊÇÁ¢¼´Ö´ÐС£Ïà·´£¬£¬ £¬ÏµÍ³Ê¹ÓÃPrint SpoolerÀ´ÖÎÀíÍÑ»ú´òÓ¡¹¤×÷¡£¾ßÌåÀ´Ëµ£¬£¬ £¬µ±Óû§Å²ÓôòÓ¡²Ù×÷ºó£¬£¬ £¬ÏµÍ³½«´òÓ¡×÷Òµ´æ´¢ÔÚÌØ¶¨µÄ¼ÙÍÑ»úÎļþ¼ÐÖС£


ĬÈÏÇé¿öÏ£¬£¬ £¬WindowsÌìÉúµÄÍÑ»ú´òÓ¡¹¤×÷ÎļþΪ.SPLÎļþ£¬£¬ £¬´ËÍâWindows»¹»á´´½¨ºó׺ÃûΪ.SHDµÄshadowÎļþ²¢Í¬SPLÎļþ×ö¹ØÁª¡£´´½¨shadowÎļþµÄÓô¦ÊÇ£ºÔÚ´òÓ¡·¨Ê½³öÏÖÎÊÌâ»òÕß´òÓ¡¹¤×÷±»¹ÒÆðºó£¬£¬ £¬PrintSpoolerÒÀÈ»Äܹ»Í¨¹ýSHDÎļþ¸´Ô­´òÓ¡¹¤×÷¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


ÔÚWindowsÏµÍ³ÖØÆô»òPrint Spooler·þÎñÖØÆôÖ®ºó£¬£¬ £¬.SHDºÍ.SPLÎļþ»á±»ÖØÐ¶ÁÈ¡ÒÔ¸´Ô­´òÓ¡¹¤×÷¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


´òÓ¡ÌáȨµÄµÀÀí


ÍÑ»ú´òÓ¡»úÖÆÊ¹µÃWindowsϵͳÔÚÖØÆôºó»á¸´Ô­¿ÉÄÜ´æÔÚµÄδִÐдòÓ¡¹¤×÷¡£µ«ÊÇ£¬£¬ £¬ÖØÆôºóµÄPrinter Spooler·þÎñ·¨Ê½Ö±½ÓʹÓÃÁËSystemȨÏÞÀ´¸´Ô­Î´Ö´ÐеĴòÓ¡×÷Òµ¡£¶ÔÓÚ´òÓ¡»ú¶Ë¿ÚΪÎļþµÄ´òÓ¡¹¤×÷£¬£¬ £¬´òÓ¡ÎļþµÄдÈëÒ²¾ÍÔÚSystemȨÏÞϱ»Ö´ÐС£Òò¶ø£¬£¬ £¬ÏµÍ³ÖØÆôʹµÃÍÑ»ú´òÓ¡¹¤×÷¾ß±¸ÁËSystemȨÏÞµÄËÁÒâÎļþдÈëÄÜÁ¦¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


´òÓ¡»úµÄÉèÖóýPowerShell¾ç±¾Í⣬£¬ £¬Í¨¹ýϵͳ½ÚÖÆÃæ°åÒ²ÄÜÉèÖ᣾ßÌåÀ´Ëµ£¬£¬ £¬Í¨¹ý¡°É豸ºÍ´òÓ¡»ú¡±ÄÜÔö³¤´òÓ¡»ú²¢ÉèÖö˿Ú¡£


OG¶«·½Ìü¡¤(Öйú´ó½)

OG¶«·½Ìü¡¤(Öйú´ó½)

OG¶«·½Ìü¡¤(Öйú´ó½)


µ«ÈôÊÇÉèÖôòÓ¡¶Ë¿ÚÃûΪ¡°C:\Windows\system32\myport.txt¡±£¬£¬ £¬Ôò»áʧ°Ü¡£


ΪºÎÉèÖÃͬÑùÎļþÃûµÄ´òÓ¡»ú¶Ë¿Ú£¬£¬ £¬Í¨¹ý½ÚÖÆÃæ°å»áʧ°Ü£¬£¬ £¬¶øÍ¨¹ýPowerShell ºÅÁîÔòÄܹ»³É¹¦ÄØ £¿£¿£¿Í¨¹ý¶ÈÎöÕâÁ½ÖÖ·½Ê½¶Ôspooler·¨Ê½Ö´ÐÐÁ÷³ÌµÄÓ°Ï죬£¬ £¬·¢ÏÖspooler·¨Ê½¶Ôͨ¹ýPowerShellºÅÁîÐÐÔö³¤´òÓ¡»ú¶Ë¿Ú·½Ê½²»×㰲ȫУÑé¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


¾ßÌåÀ´½²£¬£¬ £¬Õë¶ÔPowerShellºÅÁîÔö³¤´òÓ¡»ú¶Ë¿Ú£¬£¬ £¬spooler·¨Ê½Ö±½ÓÉèÖÃÁËÏàÓ¦µÄ´òÓ¡»ú¶Ë¿Ú×¢²á±íÏÕë¶Ô½ÚÖÆÃæ°åÔö³¤´òÓ¡»ú¶Ë¿Ú£¬£¬ £¬spooler·¨Ê½»áÊ×Ïȳ¢ÊÔ´´½¨¸Ã¶Ë¿ÚÎļþ£¬£¬ £¬´´½¨Ê§°Üºó¾Í²»»áÔÙÉèÖÃÏàÓ¦µÄ×¢²á±íÏî¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


½øÒ»²½·ÖÎöÓйØAPI·¢ÏÖ£¬£¬ £¬WindowsϵͳÌṩÁËÁ½ÖÖÔö³¤´òÓ¡»ú¶Ë¿ÚµÄAPI£¬£¬ £¬±ðÀëÊÇAddPortº¯ÊýºÍXcvDataº¯Êý¡£ÆäÖÐMSDN¶ÔAddPortµÄÃèÊö£º


¡°AddPortº¯Êýä¯ÀÀÍøÂçÒÔ²éÕÒÏÖÓж˿ڣ¬£¬ £¬²¢µ¯³ö¶Ô»°¿ò¹©Óû§Ñ¡Ôñ¡£AddPortº¯ÊýÓ¦¸Ãͨ¹ýŲÓÃEnumPortsÀ´ÑéÖ¤Óû§ÊäÈëµÄ¶Ë¿ÚÃû³Æ£¬£¬ £¬ÒÔÈ·±£²»´æÔÚ·´¸´µÄÃû³Æ¡£AddPortº¯ÊýµÄŲÓ÷½±ØÐëÓµÓнӼû¶Ë¿ÚËùÏνӵķþÎñÆ÷µÄSERVER_ACCESS_ADMINISTERȨÏÞ¡£ÒªÔö³¤¶Ë¿Ú¶ø²»ÏÔʾ¶Ô»°¿ò£¬£¬ £¬¿ÉŲÓÃXcvDataº¯Êý¶ø²»ÊÇAddPort ¡±¡£


ͨ¹ý½ÚÖÆÃæ°åÔö³¤´òÓ¡»úÔڵײãÊÇŲÓÃÁËAddPortº¯Êý£¬£¬ £¬¸Ãº¯Êý»á´¥·¢spooler·¨Ê½¶Ô¶Ë¿ÚµÄºÏ·¨ÐÔУÑ顣ͨ¹ýPowerShellºÅÁîÔö³¤´òÓ¡»úÔڵײãÔòÊÇÖ±½ÓŲÓÃXcvDataº¯Êý£¬£¬ £¬¸Ãº¯Êý²»»á´¥·¢spooler·¨Ê½¶ÔÓû§Ôö³¤µÄ¶Ë¿Ú½øÐа²È«Ð£Ñé¡£Òò¶ø£¬£¬ £¬²âÊÔ·¨Ê½AddPort.exeͨ¹ý¸Ãº¯ÊýÔڳ߶ÈÓû§È¨ÏÞÏÂÒ²ÄÜÉèÖôòÓ¡»ú¶Ë¿ÚΪÊܱ£»¤Ä¿Â¼ÖеÄÎļþ¡£


OG¶«·½Ìü¡¤(Öйú´ó½)


·ì϶²¹¶¡µÄ·ÖÎö


·ÖÎö·ì϶ÐÞ¸´ºóµÄ°æ±¾·¢ÏÖ£¬£¬ £¬Î¢ÈíÔڹؼüº¯ÊýLcmCreatePortEntry£¨×îÖÕ´´½¨´òÓ¡»ú¶Ë¿ÚµÄº¯Êý£©ÖÐÔö³¤ÁËÏàÓ¦µÄ¶Ë¿ÚºÏ·¨ÐԲ鳭´úÂë¡£ÏÂͼÊǹؼüº¯ÊýLcmCreatePortEntryÔÚÐÞ¸´Ç°ºÍÐÞ¸´ºóµÄCall Graph¶Ô±È£¬£¬ £¬Äܹ»¿´³ö£º²¹¶¡µÄÖ÷ÌâÊÇͨ¹ýº¯ÊýPortIsValid¶Ô¶Ë¿Ú½øÐкϷ¨ÐԲ鳭¡£


OG¶«·½Ìü¡¤(Öйú´ó½)



ƾ¾ÝÉÏÎĵķÖÎö¿ÉÖª£¬£¬ £¬³ß¶ÈÓû§ÊÇÎÞ·¨ÔÚϵͳĿ¼Öд´½¨ÎļþµÄ£¬£¬ £¬°Ñ¶Ë¿ÚÉèÖÃΪϵͳĿ¼ÏµÄÎļþ»áµ¼ÖÂPortIsValid¼ì²â²»µ½Ö¸±êÎļþ£¬£¬ £¬´Ó¶øÅж¨ÒªÉèÖõĶ˿ڳ¤¶Ì·¨µÄ¡£Òò¶ø£¬£¬ £¬ÔÚ²¹¶¡ÐÞ¸´ºó£¬£¬ £¬³ß¶ÈÓû§Ôö³¤´òÓ¡¶Ë¿ÚΪϵͳĿ¼ÏÂÎļþµÄ´òÓ¡»ú¾Í»áʼÖÕʧ°Ü£¬£¬ £¬´Ó¶øÔ¤·ÀÁËÏµÍ³ÖØÆôʱ¸´Ô­¶ñÒâµÄ´òÓ¡·þÎñ¡£


4.ÐÞ¸´½¨Òé


ÓÉÓڸ÷ì϶ÄÜÓ°ÏìÖÚ¶àµÄWindowsϵͳ°æ±¾£¬£¬ £¬²¢ÇÒÄܹ»Ôڳ߶ÈÓû§ÏÂÌáÒé·ì϶¹¥»÷£¬£¬ £¬½¨ÒéÊÜÓ°ÏìµÄÓû§ÊµÊ±½øÐÐϵͳ¸üлò×°Ö÷ì϶²¹¶¡¡£


´ËÍ⣬£¬ £¬Î¢ÈíµÄ°²È«¸üÐÂÖ»ÊǶԴòÓ¡¶Ë¿ÚAPI½øÐÐÁ˸üÑϸñµÄУÑé¡£µ«ÊÇ£¬£¬ £¬ÈôÊǶñÒâÎļþ¶Ë¿ÚÔÚ·ì϶ÐÞ¸´Ç°ÒѾ­´´½¨£¬£¬ £¬Ôò·ì϶¹¥»÷ÏÖʵÒѾ­ÉúЧ£¬£¬ £¬´Ëʱ½øÐÐϵͳ¸üÐÂÒÀÈ»ÊDz»°²È«µÄ¡£½¨ÒéÓû§ÏÈʹÓÃPowerShellºÅÁîGet-PrinterPortÀ´²é³­ÏµÍ³ÖÐÊÇ·ñ´æÔÚ¿ÉÒɵĴòÓ¡»ú¶Ë¿Ú£¬£¬ £¬ÔÚɾ³ý¿ÉÒɶ˿ںóÔÙÖ´ÐÐϵͳ¸üС£


²Î¿¼Á´½Ó£º

[1]https://portal.msrc.microsoft.com/en-US/security-guidance/advisory/CVE-2020-1048

[2]https://docs.microsoft.com/en-us/windows/win32/printdocs/addport

[3]https://docs.microsoft.com/en-us/previous-versions/ff564255(v%3dvs.85)

[4]https://windows-internals.com/printdemon-cve-2020-1048/