Spring MVC ·´ÉäÐÍÎļþÏÂÔØÎó²îΣº¦Í¨¸æ

Ðû²¼Ê±¼ä 2020-02-04

Îó²î±àºÅºÍ¼¶±ð


CVE±àºÅ£ºCVE-2020-5398£¬£¬£¬£¬£¬£¬£¬Î£ÏÕ¼¶±ð£º¸ßΣ£¬£¬£¬£¬£¬£¬£¬CVSS·ÖÖµ£º7.5


Ó°Ïì°æ±¾


Spring Framework£º


5.2.0 to 5.2.2

5.1.0 to 5.1.12

5.0.0 to 5.0.15


Îó²î¸ÅÊö


Pivotal Software Spring FrameworkÊÇÃÀ¹úPivotal Software¹«Ë¾µÄÒ»Ì׿ªÔ´µÄJava¡¢JavaEEÓ¦ÓóÌÐò¿ò¼Ü¡£¡£¡£¡£¡£¸Ã¿ò¼Ü¿É×ÊÖú¿ª·¢Ö°Ô±¹¹½¨¸ßÖÊÁ¿µÄÓ¦Óᣡ£¡£¡£¡£


¿ËÈÕ£¬£¬£¬£¬£¬£¬£¬Pivotal Software£¨SpringϵÁУ©¹Ù·½Ðû²¼ Spring Framework ±£´æ RFD£¨·´ÉäÐÍÎļþÏÂÔØÎó²î£©µÄÎó²î±¨¸æ£¬£¬£¬£¬£¬£¬£¬´ËÎó²îΪ¹¥»÷¿Í»§¶ËµÄÎó²î£¬£¬£¬£¬£¬£¬£¬¹Ù·½½«Îó²îÑÏÖØË®Æ½ÆÀΪ¸ß¡£¡£¡£¡£¡£±¨¸æÖ¸³ö£¬£¬£¬£¬£¬£¬£¬µ±ÏìÓ¦ÖÐÉèÖÃÁË¡°Content-Disposition¡±Í·ÇÒfilenameÊôÐÔÊÇÓû§¿É¿ØÊ±ÈÝÒ×Êܵ½RFD¹¥»÷¡£¡£¡£¡£¡£¹¥»÷Ó¦Öª×ãÒÔÏÂËùÓÐÌõ¼þ²Å¿ÉÀֳɣº


1¡¢ÏìÓ¦headerÊÇͨ¹ýorg.springframework.http.ContentDisposition¾ÙÐÐÌí¼ÓµÄ


2¡¢ÎļþÃûÊÇͨ¹ýÒÔÏ·½·¨Ö®Ò»ÉèÖõģº


ContentDisposition.Builder#filename(String)

ContentDisposition.Builder#filename(String, US_ASCII)


3¡¢filenameµÄÖµÀ´×ÔÓû§ÌṩµÄÊäÈë


4¡¢Ó¦ÓóÌÐòδɨ³ýÓû§ÌṩµÄÊäÈë


5¡¢¹¥»÷ÕßÒѽ«ÏÂÔØµÄÏìÓ¦ÄÚÈÝÖÐ×¢Èë¶ñÒâÏÂÁî


¹¥»÷Õß¿ÉʹÓÃRFDÎó²î£¬£¬£¬£¬£¬£¬£¬Á¬ÏµÉ繤µÈ·½·¨£¬£¬£¬£¬£¬£¬£¬ÈÃÓû§ÏÂÔØÒ»¸ö¶ñÒâÎļþ²¢Ö´ÐУ¬£¬£¬£¬£¬£¬£¬´Ó¶øÎ£º¦Óû§µÄÖÕ¶ËÇå¾²¡£¡£¡£¡£¡£


Îó²îÑéÖ¤


ÔÝÎÞPOC/EXP¡£¡£¡£¡£¡£


ÐÞ¸´½¨Òé


ÏÖÔÚ³§ÉÌÒÑÐû²¼Éý¼¶²¹¶¡ÒÔÐÞ¸´Îó²î£¬£¬£¬£¬£¬£¬£¬ÇëÊÜÓ°ÏìµÄÓû§Éý¼¶ÖÁ Spring Framework 5.2.3£¬£¬£¬£¬£¬£¬£¬5.1.13 »ò 5.0.16 °æ±¾£ºhttps://github.com/spring-projects/spring-framework¡£¡£¡£¡£¡£


»òÕß½ÓÄÉ׼ȷÉèÖãº


1¡¢Ó¦ÓóÌÐòδÉèÖá° Content-Disposition¡±ÏìÓ¦header¡£¡£¡£¡£¡£


2¡¢ÏìÓ¦header²»ÊÇͨ¹ýorg.springframework.http.ContentDisposition¾ÙÐÐÌí¼ÓµÄ


3¡¢ÎļþÃûÊÇͨ¹ýÒÔÏ·½·¨Ö®Ò»ÉèÖõģº


ContentDisposition.Builder#filename(String, UTF_8)

ContentDisposition.Builder#filename(String, ISO_8859_1)


4¡¢filenameµÄÖµ²»ÊÇÀ´×ÔÓû§ÌṩµÄÊäÈë


5¡¢filenameÀ´×ÔÓû§ÌṩµÄÊäÈ룬£¬£¬£¬£¬£¬£¬µ«ÓÉÓ¦ÓóÌÐòɨ³ý¡£¡£¡£¡£¡£


²Î¿¼Á´½Ó


https://pivotal.io/security/cve-2020-5398