¡¾Â©¶´Í¨¸æ¡¿Apache Log4j2¾Ü¾ø·þÎñ©¶´£¨CVE-2021-45105£©
Ðû²¼Ê±¼ä 2021-12-190x00 ©¶´¸ÅÊö
CVE ID | CVE-2021-45105 | ʱ ¼ä | 2021-12-17 |
Àà ÐÍ | Dos | µÈ ¼¶ | ¸ßΣ |
Ô¶³ÌÀûÓà | ÊÇ | Ó°Ï췶Χ | |
¹¥»÷ÅÓ´ó¶È | µÍ | ¿ÉÓÃÐÔ | ¸ß |
Óû§½»»¥ | ÎÞ | ËùÐèȨÏÞ | ÎÞ |
PoC/EXP | ÔÚÒ°ÀûÓÃ |
0x01 ©¶´ÏêÇé
Apache Log4j2ÊÇÒ»¸ö¿ªÔ´µÄJavaÈÕÖ¾¿ò¼Ü£¬±»¹ã·ºµØÓ¦ÓÃÔÚÖмä¼þ¡¢¿ª·¢¿ò¼ÜÓëWebÓ¦ÓÃÖС£
12ÔÂ18ÈÕ£¬Apache Log4j¹Ù·½ÔÙ´ÎÐû²¼Äþ¾²Í¨¸æ£¬Apache Log4j2×é¼þÖдæÔÚÒ»¸ö¾Ü¾ø·þÎñ©¶´£¨CVE-2021-45105£©£¬¸Ã©¶´µÄCVSSÆÀ·ÖΪ7.5£¬Ó°ÏìÁËApache Log4j2 2.0-beta9 µ½2.16.0µÄËùÓа汾£¬Ä¿Ç°Apache Log4j¹Ù·½ÒѾÐû²¼ÁË2.17.0°æ±¾£¨ÊÊÓÃÓÚJava 8»ò¸ü¸ß°æ±¾£©¡£
ÓÉÓÚûÓзÀÖ¹À´×Ôself-referential ²éÕҵIJ»ÊÜ¿ØÖƵĵݹ飬µ±ÈÕÖ¾ÅäÖÃʹÓôøÓÐÉÏÏÂÎIJéÕҵķÇĬÈÏģʽ½á¹¹£¨ÀýÈ磬$${ctx:loginId}£©Ê±£¬¿ØÖÆÏß³ÌÉÏÏÂÎÄÓ³Éä (MDC) ÊäÈëÊý¾ÝµÄ¹¥»÷Õß¿ÉÒÔÖÆ×÷°üÂ޵ݹé²éÕҵĶñÒâÊäÈëÊý¾Ý£¬µ¼Ö StackOverflowError £¬´Ó¶øÖÕÖ¹½ø³Ì£¬Ôì³É¾Ü¾ø·þÎñ¡£
12ÔÂ17ÈÕ£¬¶«Éƽ̨Äþ¾²Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½Apache Log4j¹Ù·½½«Apache Log4j2¾Ü¾ø·þÎñ¹¥»÷©¶´£¨CVE-2021-45046£©µÄ©¶´ÀàÐ͸ü¸ÄΪԶ³Ì´úÂëÖ´ÐЩ¶´£¨RCE£©£¬²¢½«ÆäCVSSv3·ÖÊý´Ó3.7¸ü¸ÄΪ9.0¡£
ÓÉÓÚApache Log4j 2.15.0ÖÐÐÞ¸´CVE-2021-44228ÔÚijЩ·ÇĬÈÏÅäÖÃÖÐÊDz»ÍêÕûµÄ£¬µ±ÈÕÖ¾ÅäÖÃʹÓôøÓÐÉÏÏÂÎIJéѯµÄ·ÇĬÈÏģʽ½á¹¹£¨ÀýÈ磬$${ctx:loginId}£©Ê±£¬¿ÉÒÔʹÓÃJNDI²éѯģʽÊäÈë¶ñÒâÊý¾Ý£¬µ¼ÖÂÌØ¶¨»·¾³ÏµÄÐÅϢй¶ºÍÔ¶³Ì´úÂëÖ´ÐС¢ÒÔ¼°ËùÓл·¾³Öеĵ±µØ´úÂëÖ´ÐС£
©¶´Ó°Ï췶Χ
CVE-2021-4104£ºApache Log4j 1.2
CVE-2021-44228£ºApache Log4j 2.0-beta9 - 2.12.1 ¡¢Apache Log4j 2.13.0 - 2.15.0-rc1
CVE-2021-45046£ºApache Log4j 2.0-beta9 - 2.12.1¡¢Apache Log4j 2.13.0-2.15.0
CVE-2021-45105£ºApache Log4j 2.0-beta9 - 2.16.0
0x02 ´¦Öý¨Òé
1.ͨÓÃÐÞ¸´·½°¸
ÒÑÉý¼¶µ½ Log4j 2.15.0 ºÍ2.16.0°æ±¾µÄÓû§½¨ÒéÉý¼¶µ½ Log4j 2.17.0 ÒÔÖÆÖ¹Õë¶ÔCVE-2021-44228 ¡¢CVE-2021-45046ºÍCVE-2021-45105©¶´µÄ¹¥»÷ ¡£
CVE-2021-4104£º
Apache Log4j 1.2ÖдæÔÚRCE©¶´£¨CVE-2021-4104£¬½öÅäÖÃΪʹÓÃJMSAppenderʱ´æÔÚ£¬·ÇĬÈÏ£©£¬½¨ÒéÏà¹ØÓû§Éý¼¶µ½Log4j 2µÄ×îа汾¡£
»º½â´ëÊ©£º
l ×¢ÊÍ»òɾ³ý Log4j ÅäÖÃÖÐµÄ JMSAppender¡£
l ʹÓôËÃüÁî´Ólog4j jar°üÖÐɾ³ý JMSAppender ÀàÎļþ£º
l zip -q -d log4j-*.jar org/apache/log4j/net/JMSAppender.class
²Î¿¼Á´½Ó£º
http://mail-archives.apache.org/mod_mbox/www-announce/202112.mbox/%3C1a5a0193-71c4-0613-ca92-f50f801543d9@apache.org%3E
CVE-2021-44228£º
Log4j 1.x£º²»ÊÜCVE-2021-44228©¶´Ó°Ïì¡£
Log4j 2.x£º
l ÊÜÓ°ÏìÓû§Ó¦Éý¼¶µ½Apache Log4j 2.15.0-rc2¼°ÒÔÉϰ汾£¬½¨ÒéÉý¼¶µ½ 2.16.0 °æ±¾£¨Java 8»ò¸ü¸ß°æ±¾£©¡£
l ʹÓÃJava 7µÄÓû§Ó¦Éý¼¶µ½Apache Log4j 2.12.2°æ±¾¡£
l ɾ³ý JndiLookup Àࣺzip -q -d log4j-core-*.jar org/apache/logging/log4j/core/lookup/JndiLookup.class
²Î¿¼Á´½Ó£º
https://logging.apache.org/log4j/2.x/index.html
CVE-2021-45046£º
Log4j 1.x£º²»ÊÜCVE-2021-45046©¶´Ó°Ïì¡£
l Log4j 2.x£º
l Java 8»ò¸ü¸ß°æ±¾Ó¦Éý¼¶µ½ Apache Log4j 2.16.0 °æ±¾¡£
l ʹÓÃJava 7 µÄÓû§Ó¦Éý¼¶µ½Apache Log4j 2.12.2°æ±¾¡£
l ɾ³ý JndiLookup Àࣺ zip -q -d log4j-core-*.jar org/apache/logging/log4j/core/lookup/JndiLookup.class
²Î¿¼Á´½Ó£º
http://mail-archives.apache.org/mod_mbox/www-announce/202112.mbox/%3C13e07d4e-ceb6-e510-be98-7d2ee8fa0a85@apache.org%3E
CVE-2021-45105£º
Log4j 1.x£º²»ÊÜCVE-2021-45105©¶´Ó°Ïì¡£
Log4j 2.x£ºJava 8»ò¸ü¸ß°æ±¾Óû§½¨ÒéÉý¼¶µ½ 2.17.0 °æ¡£
»º½â´ëÊ©£º
l ÔÚÈÕÖ¾ÅäÖõÄPatternLayoutÖУ¬ÓÃÏß³ÌÉÏÏÂÎÄÓ³Éäģʽ£¨%X£¬%mdc»ò%mdc£©Ìæ»»ÉÏÏÂÎIJéÕÒ£¬Èç${ctx:loginId}»ò$${ctx:loginId}¡£
l ·ñÔò£¬ÔÚÅäÖÃÖУ¬É¾³ý¶ÔÉÏÏÂÎIJéÕÒµÄÒýÓã¬Èç ${ctx£ºloginId} »ò $${ctx£ºloginId}£¬ËüÃÇÔ´×ÔÓ¦Ó÷¨Ê½ÍⲿµÄÔ´£¬Èç HTTP Í·»òÓû§ÊäÈë¡£
ÏÂÔØÁ´½Ó£º
https://logging.apache.org/log4j/2.x/download.html
×¢£ºÖ»ÓÐlog4j-core JARÎļþÊÜCVE-2021-44228¡¢CVE-2021-45046ºÍCVE-2021-45105©¶´µÄÓ°Ï졣ֻʹÓÃlog4j-api JARÎļþ¶ø²»Ê¹ÓÃlog4j-core JARÎļþµÄÓ¦Ó÷¨Ê½²»»áÊܵ½Ó°Ïì¡£
0x03 ²Î¿¼Á´½Ó
https://github.com/apache/logging-log4j2
https://logging.apache.org/log4j/2.x/security.html#CVE-2021-44228
https://logging.apache.org/log4j/2.x/security.html
0x04 ¸üа汾
°æ±¾ | ÈÕÆÚ | ÐÞ¸ÄÄÚÈÝ |
V1.0 | 2021-12-19 | Ê×´ÎÐû²¼ |
0x05 ¹ØÓÚ¶«Éƽ̨
¶«Éƽ̨¼ò½é
¶«Éƽ̨¹«Ë¾½¨Á¢ÓÚ1996Ä꣬²¢ÓÚ2010Äê6ÔÂ23ÈÕÔÚÉî½»ËùÖÐС°åÕýʽ¹ÒÅÆÉÏÊУ¬ÊǹúÄÚ¼«¾ßʵÁ¦µÄ¡¢ÓµÓÐÍêÈ«×ÔÖ÷֪ʶ²úȨµÄÍøÂçÄþ¾²²úÎï¡¢¿ÉÐÅÄþ¾²¹ÜÀíÆ½Ì¨¡¢Äþ¾²·þÎñÓë½â¾ö·½°¸µÄ×ÛºÏÌṩÉÌ¡£
¹«Ë¾×ܲ¿Î»ÓÚ±±¾©ÊÐÖйشåÈí¼þÔ°£¬ÔÚÈ«¹ú¸÷Ê¡¡¢ÊС¢×ÔÖÎÇøÉèÓзÖÖ§»ú¹¹£¬ÓµÓÐÁýÕÖÈ«¹úµÄÇþµÀÌåϵºÍ¼¼ÊõÖ§³ÖÖÐÐÄ£¬²¢ÔÚ±±¾©¡¢ÉϺ£¡¢³É¶¼¡¢¹ãÖÝ¡¢³¤É³¡¢º¼ÖÝµÈ¶àµØÉèÓÐÑз¢ÖÐÐÄ¡£
¶àÄêÀ´£¬¶«Éƽ̨ÖÂÁ¦ÓÚÌṩ¾ßÓйú¼Ê¾ºÕùÁ¦µÄ×ÔÖ÷´´ÐµÄÄþ¾²²úÎïºÍ×î¼Ñʵ¼ù·þÎñ£¬×ÊÖú¿Í»§È«ÃæÌáÉýÆäIT»ù´¡ÉèÊ©µÄÄþ¾²ÐÔºÍÉú²úЧÄÜ£¬Îª´òÔìºÍÌáÉý¹ú¼Ê»¯µÄÃñ×åÐÅÏ¢Äþ¾²¹¤ÒµÁì¾üÆ·ÅÆ¶ø²»Ð¸Å¬Á¦¡£
¹ØÓÚ¶«Éƽ̨
¶«Éƽ̨Äþ¾²Ó¦¼±ÏìÓ¦ÖÐÐÄÖ÷ÒªÕë¶ÔÖØÒªÄþ¾²Â©¶´µÄÔ¤¾¯¡¢¸ú×ٺͷÖÏíÈ«Çò×îеÄÍþвÇ鱨ºÍÄþ¾²³ÂËß¡£
¹Ø×¢ÒÔϹ«Öںţ¬»ñȡȫÇò×îÐÂÄþ¾²×ÊѶ£º