Wordpress 5.0.0Ô¶³Ì´úÂëÖ´Ðзì϶·ÖÎöÓ븴ÏÖ
°ä²¼¹¦·ò 2019-02-232ÔÂ19ÈÕ£¬£¬£¬RipsÔÚ²©¿ÍÉÏÅû¶ÁËÒ»¸ö¹ØÓÚWordpress 5.0.0Ô¶³Ì´úÂëÖ´Ðзì϶¡£¡£¸Ã·ì϶ΪCVE-2019-8942ºÍ CVE-2019-8943×éºÏ·ì϶£¬£¬£¬·ì϶´úÂëÔÚWordpressÖ÷ÌâÖÐÒÑ´æÔÚÁË6Äê¡£¡£
·ì϶ÓÉÈý²¿ÃÅ×é³É£º
£¨Ö÷ÌâÎÊÌ⣩PostMetaÄܹ»±»¸²¸Ç¡£¡£¹¥»÷ÕßÄܹ»½ÚÖÆPOSTÖÐmeta_input×ֶεÄÖµ£¬£¬£¬´Ó¶ø×ÔÓɸü¸Äwp_postmeta±íÖеÄmeta_keyÓëmeta_valueµÄÖµ¡£¡£
¸üи½¼þʱ£¬£¬£¬¹¥»÷Õß¿É×ÔÓÉÉèÖöÔÓ¦¸½¼þµÄ_wp_attached_fileµÄÖµ£¬£¬£¬²¢½áºÏ²Ã¼ôÖ°ÄÜʵÏÖĿ¼´©Ô½£¬£¬£¬´Ó¶ø½«¶ñÒâͼƬ±£Áôµ½ËÁÒâĿ¼¡£¡£
¸üÐÂÎÄÕÂʱ£¬£¬£¬¹¥»÷ÕßÄܹ»×ÔÓÉÉèÖÃÎÄÕµÄ_wp_page_templateµÄÖµ£¬£¬£¬²¢½áºÏÄ£°åÖ°ÄÜʵÏÖ±¾µØÎļþÔ̺¬£¬£¬£¬´Ó¶ø×îÖÕÔì³É´úÂëÖ´ÐС£¡£
2.1 Post Meta¸²¸Ç£¨Ö÷ÌâÎÊÌ⣩
µ±±à×ëÒ»¸öPOSTʱ»áŲÓÃedit_post²½Ö裬£¬£¬wp-admin/includes/post.php:208
´Ëʱ»á½«$_POST¸³Öµ¸ø$post_data¡£¡£¶øºó$post_dataµÄÖµÓֻᱻ´øÈëµ½wp_update_postº¯ÊýÖС£¡£
¸ú×Ùwp_update_postº¯Êý£¬£¬£¬wp-includes/post.php:3969
Ôڸú¯Êýĩ⣬£¬£¬³ÇÊÐŲÓÃwp_insert_postº¯Êý£¬£¬£¬²¢½«$postarr´«Èëµ½¸Ãº¯ÊýÖУ¬£¬£¬wp_insert_postº¯ÊýÂÔ³¤£¬£¬£¬Ôڸú¯ÊýÖÐÓÐÕâÑùÒ»¶Î´úÂ룬£¬£¬wp-includes/post.php:3779 ¡£¡£
¶Ô$postarr['meta_input']×öÒ»¸ö±éÀú£¬£¬£¬²¢½«¼üÖµ¶¼´øÈëµ½update_post_metaº¯ÊýÖУ¬£¬£¬¸Ãº¯ÊýÄÚÈÝÈçÏ£º
ŲÓÃÁËupdate_metadataº¯Êý£¬£¬£¬¶ÔÓ¦µÄ$meta_keyºÍ$meta_value¶¼Êǹ¥»÷Õ߿ɿصġ£¡£¸Ãº¯ÊýÖØÒªÖ°ÄܾÍÊÇwp_postmeta±í½øÐиüкͲåÈë¡£¡£
wp_postmeta±í½á¹¹ÈçÏÂ:
ͨ¹ý¸Ãº¯Êý£¬£¬£¬¹¥»÷ÕßÄܹ»×ÔÓÉÔö³¤ºÍÅú¸Ä¶ÔÓ¦post_idµÄmeta_keyºÍmeta_valueµÄÖµ¡£¡£
Ŀ¼´©Ô½ÎÊÌâÊÇÒÔPost Meta¸²¸ÇΪÆÌµæµÄ¡£¡£ÔÚwp-admin/includes/ajax-actions.php:3520
ÔÚwp_ajax_crop_imageº¯ÊýÖУ¬£¬£¬µÚÒ»Ðоʹ«ÈëÁËÒ»¸ö$_POST['id']²ÎÊý¡£¡£¶øºó»¹´«ÈëÁË$_POST['cropDetails']²ÎÊý¡£¡£¶¼Êǹ¥»÷Õ߿ɿصġ£¡£²¢½«ÕâЩֵ´øÈëµ½ÁËwp_crop_imageº¯ÊýÖУ¬£¬£¬º¯ÊýÌåÈçÏ£º
ÔÚ28ÐУ¬£¬£¬»á½øÈë¸Ãif£¬£¬£¬´«ÈëµÄ$srcÊǹ¥»÷Õ߿ɿص쬣¬£¬´øÈëµ½get_attached_fileº¯ÊýÖУ¬£¬£¬º¯ÊýÌåÈçÏ£º
ŲÓÃget_post_metaº¯Êý£¬£¬£¬½«wp_postmetaÄÚÍâ¶ÔÓ¦µÄpost_id×Ö¶Îmeta_keyֵΪ_wp_attached_fileµÄmeta_valueÖµ²éÎʳöÀ´²¢·µ»Ø¡£¡£ÓÉÉÏÎÄ¿ÉÖª£¬£¬£¬¸ÃÖµÊǹ¥»÷ÕßÄܹ»×Ô¼º¸²¸ÇµÄ£¬£¬£¬Êǿɿصġ£¡£
½øÈëµÚ¶þ¸öif·ÖÖ§ÖУ¬£¬£¬Å²ÓÃwp_get_attachment_urlº¯Êý£¬£¬£¬²é¿´¸Ãº¯Êý£º
ÈçÉÏͼ±ê×¢µÄËùʾ£¬£¬£¬×îºóÐγɵÄÊÇÒ»¸öurlÁ´½Ó¡£¡£
ÈôÊÇ£¬£¬£¬¹¥»÷Õß½«meta_value¸ü¸ÄΪ2019/02/evil.jpg#/../../../../../theme-compat/evil.jpg¡£¡£
×îºó£¬£¬£¬ÐγɵÄurl¾ÍÊÇÕâÑùhttp://localhost/wp-content/uploads/2019/02/evil.jpg#/../../../../../theme-compat/evil.jpg¡£¡£
¸ú×ٸú¯Êý£º
ÆäÖÐÓÐÒ»²½Ï¸½ÚµÄ²Ù×÷ÊÇÔÚ_wp_image_editor_chooseÕâ¸öº¯ÊýÖÐ:
WordpressÌṩÁËÁ½ÖÖ·½Ê½À´´¦ÖÃͼƬ£¬£¬£¬ImagickÊÇÓÅÏȼ¶×î¸ßµÄ£¬£¬£¬GDÆä´Î¡£¡£Õâ¸ö°¤´Î»áÓ°Ïì×îÖÕ»·¾³µÄÀûÓᣡ£
¶øImagickºÍGD¶ÔͼƬҲÓÐ·ÖÆçµÄ´¦Öãº
Imagick²»»áÈ¥³ýµôͼƬÖеÄexif²¿ÃÅ£¬£¬£¬ËùÒÔÎÒÃÇÄܹ»½«´ýÖ´ÐÐpayload´úÂë²ÎÓëµ½exif²¿ÃÅ¡£¡£
GD»áÈ¥³ýͼƬµÄexif²¿ÃÅ£¬£¬£¬²¢ÇÒÆäÖеÄphpcodeºÜÄÑ´æ»î¡£¡£³ý·Çͨ¹ý¾«ÐÄ»ú¹ØÒ»ÕÅͼƬÄÜÁ¦¹»¡£¡£
ÔÚÕâÀïÎÒÃÇÑ¡ÔñImagick¿â£¬£¬£¬Ñ¡ÔñºÃͼƬ´¦ÖÿâÖ®ºó¾Í·µ»Ø¸Ã¿â²¢Å²ÓÃload²½Öè¼ÓÔØurl£º
ÕâÀïÓÐÒ»¸ö¿Óµã£¬£¬£¬¾ÍÊÇImagick´¦ÖÃÀàµÄloadº¯ÊýÖÐŲÓõÄÊÇreadImageº¯Êý£¬£¬£¬µ«Ôڸ߰汾µÄImagickÉϸú¯Êý²»Ö§³ÖÔ¶³ÌͼƬÁ´½Ó£¬£¬£¬Òò¶øÎÒѡȡImagick-6.9.7À´¸´ÏÖ£¬£¬£¬»·¾³ÈçÏÂͼ£º
ŲÓÃÍêloadº¯Êýºó£¬£¬£¬¾ÍÊǶԻñÈ¡µ½µÄͼƬÄÚÈݽøÐвüô´¦Ö㬣¬£¬¶øºó°ÑÐÂÌìÉúµÄͼƬ½øÐб£Áô£¬£¬£¬²é¿´±£ÁôÐÂÎļþµÄ²Ù×÷£¨Ôì³ÉĿ¼´©Ô½µÄÖյ㣩£º
$dst_fileÊDZ£ÁôµÄÎļþÃû£¬£¬£¬ÌìÉú¹æ¶¨ÈçÉÏͼ±ê×¢Ëùʾ¡£¡£Òò¶øÌìÉú×îÖÕÎļþõ辶Ϊ£ºuploaddir/2019/02/cropped-evil.jpg#/../../../../../theme-compat/cropped-evil.jpg¡£¡£
ÕâÀïÓÐÒ»¸ö°ÑÎȵ㣬£¬£¬¾ÍÊÇ»áÏÈŲÓÃwp_mkdir_pº¯ÊýÀ´´´½¨Ä¿Â¼£¬£¬£¬¶øºóÔÙŲÓÃsaveº¯Êý±£ÁôÎļþ¡£¡£
saveº¯ÊýÖ÷ÌâÈçÏÂͼ£º
ÕâÀïŲÓÃÁËmake_imageº¯Êý£¬£¬£¬º¯ÊýÌåÈçÏ£º
ÕâÀïÓÖÓÐÒ»¸ö¿Óµã£¬£¬£¬ÕâÀï»áÓÃcall_user_func_arrayº¯ÊýÀ´Å²ÓÃImagickµÄwriteImageº¯Êý£¬£¬£¬²¢½«$filename´«µÝ½øÈ¥£¬£¬£¬ÖµÍ×ÌùÐĵÄÒ»µãÊǸú¯ÊýÔÚLinuxϲ»Ö§³Ö²»´æÔÚµÄÄ¿Â¼Ìø×ª¡£¡£
µ«ÊÇΪÁ˴ﵽĿ¼´©Ô½µÄÖ÷ÕÅ£¬£¬£¬ÎÒÃÇÕâÀï´«ÈëµÄ$filename¾ÍÊÇuploaddir/2019/02/cropped-evil.jpg#/../../../../../theme-compat/cropped-evil.jpg ¡£¡£
ÓÉÓÚcropped-evil.jpg#ÊǸö²»´æÔÚµÄĿ¼£¬£¬£¬Òò¶ø¸Ãº¯Êý»áŲÓÃʧ°ÜÅ׳öÃýÎóÖÕÖ¹Á÷³Ì£¬£¬£¬ÌìȻҲÎÞ·¨Å²ÓÃfopenºÍfwrite½øÐÐдÎļþµÄ²Ù×÷¡£¡£
½èÖúÂÅ´ÎÉÏ´«²Ã¼ô¾ÍÄܹ»ÈƹýÕâ¸ö¿Óµã£¬£¬£¬µ«ÊÇÌìÉúµÄÐÂͼƬÓÖÓÐʲôÓÃÄØ£¿
ÔÚwp-includes/template-loader.php:55
ÕâÀïŲÓÃÁËget_single_templateº¯Êý£º
µÚÒ»ÐлñȡҪÇóµÄ¶ÔÏ󡣡£µ±ÎÒÃÇͨ¹ý·ÓÉä¯ÀÀÎÄÕÂʱÕâÀï»á·µ»ØWP_Post¶ÔÏ󣬣¬£¬ÆäÖÐÔ̺¬ÎÄÕµÄһЩÊôÐÔ¡£¡£
¶øºó½«¸Ã¶ÔÏó´øÈëµ½ÁËget_page_template_slugº¯ÊýÖУ¬£¬£¬º¯ÊýÌåÈçÏ£º
ƾ¾Ýpost_id´Ówp_postmeta±íÖÐÈ¡³ömeta_key×Ö¶ÎֵΪ_wp_page_templateµÄmeta_valueµÄÖµ²¢·µ»Ø¡£¡£
´ÓÖ÷ÌâÎÊÌâ¿ÉÖª£¬£¬£¬ÕâÀï·µ»ØµÄmeta_valueµÄֵͬÑùÊÇÄܹ»±»¹¥»÷Õß×ÔÓɸ²¸ÇµÄ£¬£¬£¬Òò¶ø¸ÃÖµÊǹ¥»÷Õ߿ɿصġ£¡£
ŲÓÃlocate_templateº¯Êý£¬£¬£¬º¯ÊýÌåÈçÏ£º
ÕâÀï×öõè¾¶µÄÆ´½ÓºÍÅжϡ£¡£$template_nameÊǿɿص쬣¬£¬Òò¶ø½áºÏÉÏÎĵÄĿ¼´©Ô½£¬£¬£¬½«ÐÂÌìÉúµÄͼƬ·Åµ½theme-compatĿ¼Ï¼´¿É¡£¡£
ŲÓÃinclude½«Í¼Æ¬Ô̺¬£¬£¬£¬Ö´ÐдúÂë¡£¡£
3¡¢¡¢¡¢·ì϶¸´ÏÖ
ÕâÀ£¬£¬ÎÒÃÇѡȡmac os+php7.1+wordpress4.9.8+imagick6.9.7½øÐи´ÏÖ¡£¡£
¶øºó¸üиÃͼƬÐÅÏ¢£º
²¢Ê¹ÓÃburp×¥°ü£¬£¬£¬¸ü¸ÄÈçͼËùʾ£º
¶øºóÆðÍ·²Ã¼ôͼƬ£¬£¬£¬µã»÷edit Image²¢×¥°üµÃµ½nonce²¢»ú¹Ø±¨ÎÄ¡£¡£
³ÖÐøÉÏ´«²¢²Ã¼ôÒ»ÕÅÃûΪfinally.jpgµÄͼƬ£¬£¬£¬³É¹¦´´½¨Îļþ£º
¶øºóÐÂÔö³¤Ò»ÆªÎÄÕ£¬£¬£¬ÔÚupdateʱ³ÖÐø×¥°ü¸ü¸ÄÈçÏÂͼËùʾ£º
½áÊøºó¡£¡£²é¿´¸ÃÎÄÕ£¬£¬£¬³É¹¦´¥·¢phpinfo!
4¡¢¡¢¡¢²¹¶¡·ÖÎö
Ôö³¤ÁË_wp_get_allowed_postdata²½Ö裬£¬£¬½«meta_input×ֶδÓPOST±¨ÎÄÖÐÈ¥µôÁË¡£¡£


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