¡¾·ì϶¹«¸æ¡¿Apache Log4j2»Ø¾ø·þÎñ·ì϶£¨CVE-2021-45046£©
°ä²¼¹¦·ò 2021-12-160x00 ·ì϶¸ÅÊö
CVE ID | CVE-2021-45046 | ʱ ¼ä | 2021-12-14 |
Àà ÐÍ | Dos | µÈ ¼¶ | ÖÐΣ |
Ô¶³ÌÀûÓà | ÊÇ | Ó°ÏìÁìÓò | |
¹¥»÷¸´ÔÓ¶È | ¸ß | ¿ÉÓÃÐÔ | µÍ |
Óû§½»»¥ | ÎÞ | ËùÐèȨÏÞ | ÎÞ |
PoC/EXP | ÔÚÒ°ÀûÓÃ |
0x01 ·ì϶ÏêÇé

Apache Log4j2ÊÇÒ»¸ö¿ªÔ´µÄJavaÈÕÖ¾¿ò¼Ü£¬±»¿í·ºµØÀûÓÃÔÚÖÐÑë¼þ¡¢¿ª·¢¿ò¼ÜÓëWebÀûÓÃÖС£
²¿Ãʦ·òÏß
11ÔÂ24ÈÕ£º°¢ÀïÔÆ°²È«ÍŶÓÏòApache¹Ù·½»ã±¨ÁËApache Log4j2Ô¶³Ì´úÂëÖ´Ðзì϶CVE-2021-44228£»
12ÔÂ7ÈÕ£ºApache Log4j2¹Ù·½°ä²¼log4j2-2.15.0-rc1²¢µÚÒ»´Î½¨¸´CVE-2021-44228·ì϶£»
12ÔÂ9ÈÕ£ºGA»Æ½ð¼×°²È«Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½Apache Log4j2 Ô¶³Ì´úÂëÖ´Ðзì϶CVE-2021-44228£¨CVSSÆÀ·Ö10.0£©£¬¸÷²úÆ·Ïß·¢Õ¹Ó¦¼±ÏìÓ¦´ëÖá£
12ÔÂ14ÈÕ£ºGA»Æ½ð¼×°²È«Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½Apache Log4j 1.2Ô¶³Ì´úÂëÖ´Ðзì϶CVE-2021-4104£¨CVSSÆÀ·Ö6.6£©¡£
12ÔÂ15ÈÕ£ºGA»Æ½ð¼×°²È«Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½Apache Log4j2»Ø¾ø·þÎñ·ì϶CVE-2021-45046£¨CVSSÆÀ·Ö3.7£©¡£
Apache Log4j2¹Ù·½½¨¸´¹æ»®
12ÔÂ7ÈÕ£ºApache Log4j2¹Ù·½°ä²¼log4j2-2.15.0-rc1²¢µÚÒ»´Î½¨¸´CVE-2021-44228£»
12ÔÂ10ÈÕ£ºlog4j2-2.15.0-rc1´æÔÚBypass£¬Apache Log4j2¹Ù·½°ä²¼log4j2-2.15.0-rc2½¨¸´bypass·ì϶¡£
12ÔÂ11ÈÕ£ºApache Log4j2¹Ù·½°ä²¼ÁË2.15.0 °æ±¾£¬ÒÔ½¨¸´CVE-2021-44228¡£¹ÌÈ» 2.15.0 °æ±¾½â¾öÁËMessage LookupsÖ°ÄܺÍJNDI ½Ó¼û·½Ê½µÄÎÊÌ⣬µ« Log4jÍŶÓÒÔΪĬÈÏÆôÓà JNDI ´æÔÚ°²È«·çÏÕ£¬ÇÒ2.15.0°æ±¾´æÔÚCVE-2021-45046·ì϶¡£
12ÔÂ13ÈÕ£ºApache Log4j2¹Ù·½°ä²¼ÁËLog4j 2.16.0°æ±¾£¨Java 8»ò¸ü¸ß°æ±¾£©£¬¸Ã°æ±¾É¾³ýÁËMessage LookupsÖ°Äܲ¢Ä¬ÈϽûÓÃJNDIÖ°ÄÜ£¬²¢´Ó¸Ã°æ±¾ÆðͷĬÈϽûÓÃJNDIÖ°ÄÜ£¬µ«Äܹ»Í¨¹ý½«log4j2.enableJndiÉèÖÃΪ true ÒÔÆôÓà JNDI¡£´Ë±í£¬Log4j´Ë¿Ì½«ºÍ̸ĬÈÏÏÞ¶ÈΪ½öjava¡¢ldapºÍldaps£¬²¢½«ldapºÍ̸ÏÞ¶ÈΪֻÄܽӼûJavaÔʼ¶ÔÏó¡£±¾µØÖ÷»úÒÔ±íµÄÖ÷»ú±ØÒª±»Ã÷È·ÔÊÐí¡£
12ÔÂ15ÈÕ£ºApache Log4j2¹Ù·½°ä²¼ÁËApache Log4j 2.12.2°æ±¾£¬¸Ã°æ±¾½¨¸´ÁËCVE-2021-44228ºÍCVE-2021-45046£¬ºÏÓÃÓÚÈÔÔÚʹÓÃJava 7µÄÓû§¡£
¹©¸øÁ´Ó°Ïì
ƾ¾Ý·ÇȨÍþͳ¼Æ£¬Ö±½ÓºÍ¼ä½ÓÒýÓÃLog4jµÄ¿ªÔ´×é¼þÔ¤¼Æ³¬¹ý17Íò¸ö¡£Ä¿Ç°ÒÑÖªµÄÊÜÓ°ÏìµÄÀûÓúÍ×é¼þÔ̺¬£ºApache Solr¡¢Apache Struts2¡¢Apache Flink¡¢Apache Druid¡¢Apache Log4j SLF4J Binding¡¢spring-boot-strater-log4j2¡¢Hadoop Hive¡¢ElasticSearch¡¢Jedis¡¢Logging¡¢LogstashÒÔ¼°VMware¶à¸ö²úÆ·µÈ¡£
ÓÉÓڸ÷ì϶µÄÓ°ÏìÁìÓòÊÇÈ«ÇòÐԵ쬹ú±í¸÷´ó³ÛÃûÆóÒµºÍ×éÖ¯µÄ²úÆ·¾ùÊÜÓ°Ï죬ÈçAmazon¡¢Apache¡¢Atlassian¡¢Cisco¡¢Debian¡¢Docker¡¢Fortinet¡¢Google¡¢IBM¡¢Ó¢Ìضû¡¢Juniper Networ¡¢Î¢Èí¡¢Oracle¡¢Red Hat¡¢UbuntuºÍVMwareµÈ¡£
CVE-2021-44228·ì϶µÄÀûÓÃÄѶȵͣ¬Ä¬ÈÏÅäÖü´¿ÉÔ¶³ÌÀûÓã¬ÇÒPoC/EXPÒÑÔÚ»¥ÁªÍøÉϹ«¿ª£¬ÏÖÒѱ»ÍøÂç·¸×ïÍÅ»ï¿í·ºÀûÓá£
·ì϶ӰÏìÁìÓò
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
0x02 ´ëÖý¨Òé
1.ͨÓý¨¸´¹æ»®
ÒÑÉý¼¶µ½ Log4j 2.15.0 °æ±¾µÄÓû§½¨ÒéÉý¼¶µ½ Log4j 2.16.0 ÒÔÔ¤·ÀÕë¶ÔCVE-2021-44228 ºÍ CVE-2021-45046·ì϶µÄ¹¥»÷ ¡£
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·ì϶ӰÏì¡£
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
ÏÂÔØÁ´½Ó£º
https://logging.apache.org/log4j/2.x/download.html
×¢£ºÖ»ÓÐlog4j-core JARÎļþÊÜCVE-2021-44228ºÍCVE-2021-45046·ì϶µÄÓ°Ï졣ֻʹÓÃlog4j-api JARÎļþ¶ø²»Ê¹ÓÃlog4j-core JARÎļþµÄÀûÓ÷¨Ê½²»»áÊܵ½Ó°Ïì¡£
2.ͨÓÃһʱ¹æ»®£¨CVE-2021-44228£©
l ½¨ÒéJDKʹÓÃ6u211¡¢7u201¡¢8u191¡¢11.0.1¼°ÒÔÉϵİ汾£»
l ¶ÔÓÚ>=2.10°æ±¾£º
Ôö³¤jvmÆô¶¯²ÎÊý:-Dlog4j2.formatMsgNoLookups=true£»
ÔÚlog4j2.component.propertiesÅäÖÃÎļþÖÐÔö³¤ÈçÏÂÄÚÈÝ£ºlog4j2.formatMsgNoLookups=true£»
ϵͳ»·¾³±äÁ¿Öн«LOG4J_FORMAT_MSG_NO_LOOKUPSÉèÖÃΪtrue£»
l ¶ÔÓÚ2.7-2.14.1°æ±¾£º
Äܹ»Åú¸ÄËùÓÐPatternLayoutģʽ£¬½«ÐÂÎÅת»»Æ÷Ö¸¶¨Îª%m{nolookups}£¬¶ø²»½ö½öÊÇ%m¡£
l ¶ÔÓÚ2.0-beta9-2.7°æ±¾£º
ΨһµÄ»º½â´ëÊ©ÊÇɾ³ýjndiookupÀࣺzip -q -d log4j-core-*.jar org/apache/logging/log4j/core/lookup/JndiLookup.class
l ²»ÈÝ×°ÖÃlog4jµÄ·þÎñÆ÷½Ó¼û±íÍø£¬²¢ÔÚÌìǵ¶ÔdnslogÓйØÓòÃû½Ó¼û½øÐмì²â¡£
0x03 ²Î¿¼Á´½Ó
https://github.com/apache/logging-log4j2
https://github.com/apache/logging-log4j2/releases/tag/log4j-2.15.0-rc2
https://mp.weixin.qq.com/s/J5H9aZVhwQaVn3LvKi2Kqw
https://logging.apache.org/log4j/2.x/security.html#CVE-2021-44228
https://www.cisa.gov/uscert/apache-log4j-vulnerability-guidance
0x04 ¸üа汾
°æ±¾ | ÈÕÆÚ | Åú¸ÄÄÚÈÝ |
V1.0 | 2021-12-9 | ³õ´Î°ä²¼ |
V2.0 | 2021-12-10 | Åú¸Äϸ½Ú |
V3.0 | 2021-12-10 | Åú¸Äbug |
V4.0 | 2021-12-12 | ÐÂÔöCVE£ID¼°²¿ÃÅÄÚÈÝ¡¢Åú¸Ä»º½â´ëÊ©¡£ |
V5.0 | 2021-12-14 | Åú¸Ä´ëÖý¨Òé |
V6.0 | 2021-12-16 | Åú¸Äϸ½Ú |
0x05 ¹ØÓÚGA»Æ½ð¼×
GA»Æ½ð¼×¼ò½é
GA»Æ½ð¼×¹«Ë¾³ÉÁ¢ÓÚ1996Ä꣬²¢ÓÚ2010Äê6ÔÂ23ÈÕÔÚÉî½»ËùÖÐÓ×°åÕýʽ¹ÒÅÆÉÏÊУ¬ÊǹúÄÚ¼«¾ßʵÁ¦µÄ¡¢Õ¼ÓÐÆëÈ«×ÔÖ÷֪ʶ²úȨµÄÍøÂ簲ȫ²úÆ·¡¢¿ÉÐŰ²È«ÖÎÀíÆ½Ì¨¡¢°²È«·þÎñÓë½â¾ö¹æ»®µÄ×ÛºÏÌṩÉÌ¡£
¹«Ë¾×ܲ¿Î»ÓÚ±±¾©ÊÐÖйشåÈí¼þÔ°£¬ÔÚÈ«¹ú¸÷Ê¡¡¢ÊÓ×¢×ÔÖÎÇøÉèÓзÖÖ§»ú¹¹£¬Õ¼Óи²¸ÇÈ«¹úµÄÇþ·ϵͳºÍ¼¼ÊõÖ§³ÖÖÐÐÄ£¬²¢ÔÚ±±¾©¡¢ÉϺ£¡¢³É¶¼¡¢¹ãÖÝ¡¢³¤É³¡¢º¼ÖÝµÈ¶àµØÉèÓÐÑз¢ÖÐÐÄ¡£
¶àÄêÀ´£¬GA»Æ½ð¼×ÖÂÁ¦ÓÚÌṩӵÓйú¼Ê¾ºÕùÁ¦µÄ×ÔÖ÷´´Ðµİ²È«²úÆ·ºÍ×î¼Ñʵ¼Ê·þÎñ£¬Ô®ÊÖ¿Í»§È«ÃæÌáÉýÆäIT»ù´¡ÉèÊ©µÄ°²È«ÐԺͳö²úЧÁ¦£¬Îª´òÔìºÍÌáÉý¹ú¼Ê»¯µÄÃñ×åÐÅÏ¢°²È«²úÒµÁì¾üÆ·ÅÆ¶ø²»Ð¸ÖÂÁ¦¡£
¹ØÓÚGA»Æ½ð¼×
GA»Æ½ð¼×°²È«Ó¦¼±ÏìÓ¦ÖÐÐÄÖØÒªÕë¶Ô³ÁÒª°²È«·ì϶µÄÔ¤¾¯¡¢¸ú×ٺͷÖÏíÈ«Çò×îеÄÍþвµý±¨ºÍ°²È«»ã±¨¡£
¹Ø×¢ÒÔϹ«¼ÒºÅ£¬»ñȡȫÇò×îа²È«×ÊѶ£º



¾©¹«Íø°²±¸11010802024551ºÅ