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.·ì϶ÑéÖ¤


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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾

GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


3.·ì϶µÀÀí


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


´òÓ¡»ú¹¤×÷»úÔì


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


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

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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


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

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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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

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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾

GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


ÍÑ»ú´òÓ¡µÄ»úÔì


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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾

GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾

GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾


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


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


GA»Æ½ð¼×¡¤(ÖйúÇø)¹Ù·½ÍøÕ¾



ƾ¾ÝÉÏÎĵķÖÎö¿ÉÖª£¬³ß¶ÈÓû§ÊÇÎÞ·¨ÔÚϵͳĿ¼Öд´½¨ÎļþµÄ£¬°Ñ¶Ë¿ÚÉèÖÃΪϵͳĿ¼ÏµÄÎļþ»áµ¼ÖÂ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/