¡¾·ì϶¹«¸æ¡¿Apache Log4j2»Ø¾ø·þÎñ·ì϶£¨CVE-2021-45046£©

°ä²¼¹¦·ò 2021-12-16


0x00 ·ì϶¸ÅÊö

CVE     ID

CVE-2021-45046

ʱ      ¼ä

2021-12-14

Àà      ÐÍ

Dos

µÈ      ¼¶

ÖÐΣ

Ô¶³ÌÀûÓÃ

ÊÇ

Ó°ÏìÁìÓò


¹¥»÷¸´ÔÓ¶È

¸ß

¿ÉÓÃÐÔ

µÍ

Óû§½»»¥

 ÎÞ

ËùÐèȨÏÞ

ÎÞ

PoC/EXP


ÔÚÒ°ÀûÓÃ


 

0x01 ·ì϶ÏêÇé

image.png

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ÈÕ£º±¦ÔËÀ³¹Ù·½ÍøÕ¾°²È«Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½Apache Log4j2 Ô¶³Ì´úÂëÖ´Ðзì϶CVE-2021-44228£¨CVSSÆÀ·Ö10.0£©£¬¸÷²úÆ·Ïß·¢Õ¹Ó¦¼±ÏìÓ¦´ëÖá£

12ÔÂ14ÈÕ£º±¦ÔËÀ³¹Ù·½ÍøÕ¾°²È«Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½Apache Log4j 1.2Ô¶³Ì´úÂëÖ´Ðзì϶CVE-2021-4104£¨CVSSÆÀ·Ö6.6£©¡£

12ÔÂ15ÈÕ£º±¦ÔËÀ³¹Ù·½ÍøÕ¾°²È«Ó¦¼±ÏìÓ¦ÖÐÐļà²âµ½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 ¹ØÓÚ±¦ÔËÀ³¹Ù·½ÍøÕ¾

±¦ÔËÀ³¹Ù·½ÍøÕ¾¼ò½é

±¦ÔËÀ³¹Ù·½ÍøÕ¾¹«Ë¾³ÉÁ¢ÓÚ1996Ä꣬²¢ÓÚ2010Äê6ÔÂ23ÈÕÔÚÉî½»ËùÖÐÓ×°åÕýʽ¹ÒÅÆÉÏÊУ¬ÊǹúÄÚ¼«¾ßʵÁ¦µÄ¡¢Õ¼ÓÐÆëÈ«×ÔÖ÷֪ʶ²úȨµÄÍøÂ簲ȫ²úÆ·¡¢¿ÉÐŰ²È«ÖÎÀíÆ½Ì¨¡¢°²È«·þÎñÓë½â¾ö¹æ»®µÄ×ÛºÏÌṩÉÌ¡£

¹«Ë¾×ܲ¿Î»ÓÚ±±¾©ÊÐÖйشåÈí¼þÔ°£¬ÔÚÈ«¹ú¸÷Ê¡¡¢ÊÓ×¢×ÔÖÎÇøÉèÓзÖÖ§»ú¹¹£¬Õ¼Óи²¸ÇÈ«¹úµÄÇþ·ϵͳºÍ¼¼ÊõÖ§³ÖÖÐÐÄ£¬²¢ÔÚ±±¾©¡¢ÉϺ£¡¢³É¶¼¡¢ÕÑͨ¡¢³¤É³¡¢¾£ÃÅµÈ¶àµØÉèÓÐÑз¢ÖÐÐÄ¡£

¶àÄêÀ´£¬±¦ÔËÀ³¹Ù·½ÍøÕ¾ÖÂÁ¦ÓÚÌṩӵÓйú¼Ê¾ºÕùÁ¦µÄ×ÔÖ÷´´Ðµİ²È«²úÆ·ºÍ×î¼Ñʵ¼Ê·þÎñ£¬Ô®ÊÖ¿Í»§È«ÃæÌáÉýÆäIT»ù´¡ÉèÊ©µÄ°²È«ÐԺͳö²úЧÁ¦£¬Îª´òÔìºÍÌáÉý¹ú¼Ê»¯µÄÃñ×åÐÅÏ¢°²È«²úÒµÁì¾üÆ·ÅÆ¶ø²»Ð¸ÖÂÁ¦¡£


¹ØÓÚ±¦ÔËÀ³¹Ù·½ÍøÕ¾

±¦ÔËÀ³¹Ù·½ÍøÕ¾°²È«Ó¦¼±ÏìÓ¦ÖÐÐÄÖØÒªÕë¶Ô³ÁÒª°²È«·ì϶µÄÔ¤¾¯¡¢¸ú×ٺͷÖÏíÈ«Çò×îеÄÍþвµý±¨ºÍ°²È«»ã±¨¡£

¹Ø×¢ÒÔϹ«¼ÒºÅ£¬»ñȡȫÇò×îа²È«×ÊѶ£º

image.png