¡¾Îó²îͨ¸æ¡¿AdonisJS Multipart Îļþ´¦Öóͷ£Â·¾¶±éÀúÎó²î(CVE-2026-21440)

Ðû²¼Ê±¼ä 2026-01-05

Ò»¡¢Îó²î¸ÅÊö


Îó²îÃû³Æ

AdonisJS Multipart Îļþ´¦Öóͷ£Â·¾¶±éÀúÎó²î

CVE   ID

CVE-2026-21440

Îó²îÀàÐÍ

·¾¶±éÀú

·¢Ã÷ʱ¼ä

2026-1-5

Îó²îÆÀ·Ö

9.2

Îó²îÆ·¼¶

ÑÏÖØ

¹¥»÷ÏòÁ¿

ÍøÂç

ËùÐèȨÏÞ

ÎÞ

ʹÓÃÄѶÈ

µÍ

Óû§½»»¥

²»ÐèÒª

PoC/EXP

δ¹ûÕæ

ÔÚҰʹÓÃ

δ·¢Ã÷


AdonisJSÊÇÒ»¸ö»ùÓÚNode.jsµÄȫջWebÓ¦Óÿò¼Ü£¬£¬£¬£¬½ÓÄÉMVC¼Ü¹¹£¬£¬£¬£¬Ö¼ÔÚÌṩһÖÖ¸ßЧ¡¢¾«Á·ÇÒ¾ßÓÐÓÅÒ쿪·¢ÌåÑéµÄ¿ª·¢·½·¨¡£¡£¡£ ¡£¡£¡£ËüÄÚÖÃÁ˶àÖÖ³£Óù¦Ð§£¬£¬£¬£¬ÈçÈÏÖ¤¡¢Êý¾Ý¿âǨáã¡¢ÑéÖ¤¡¢Óʼþ´¦Öóͷ£¡¢ÎļþÉÏ´«µÈ£¬£¬£¬£¬×ÊÖú¿ª·¢ÕßרעÓÚÓªÒµÂß¼­¶øÎÞÐè¹ý¶à¹Ø×¢µ×²ãʵÏÖ¡£¡£¡£ ¡£¡£¡£AdonisJSÌṩÁËÍêÉÆµÄCLI¹¤¾ßºÍǿʢµÄ·ÓÉϵͳ£¬£¬£¬£¬ÊÊÓÃÓÚ¹¹½¨´ÓСÐÍÓ¦Óõ½´óÐÍÆóÒµ¼¶Ó¦ÓõÄÏîÄ¿¡£¡£¡£ ¡£¡£¡£


2026Äê1ÔÂ5ÈÕ£¬£¬£¬£¬Z6×ðÁú¿­Ê±¼¯ÍÅVSRC¼à²âµ½AdonisJSµÄ@adonisjs/bodyparser°ü±£´æÂ·¾¶±éÀúÎó²î¡£¡£¡£ ¡£¡£¡£¹¥»÷Õß¿Éͨ¹ý½á¹¹¶ñÒâÎļþÃû£¬£¬£¬£¬Ê¹ÓÃMultipartFile.move(location,options)µÄĬÈÏÑ¡Ï£¬£¬£¬½«ÎļþдÈëЧÀÍÆ÷í§ÒâλÖ㬣¬£¬£¬ÈƹýÔ¤ÆÚµÄÉÏ´«Ä¿Â¼¡£¡£¡£ ¡£¡£¡£ÈôδÏÔʽÉèÖÃoptions.name»òoptions.overwrite£¬£¬£¬£¬¹¥»÷Õß¿Éͨ¹ý·¾¶±éÀúдÈëÃô¸ÐÎļþ£¬£¬£¬£¬¿ÉÄܵ¼ÖÂÔ¶³Ì´úÂëÖ´ÐУ¨RCE£©¡£¡£¡£ ¡£¡£¡£Îó²îÆÀ·Ö9.2£¬£¬£¬£¬Îó²î¼¶±ðÑÏÖØ¡£¡£¡£ ¡£¡£¡£


¶þ¡¢Ó°Ïì¹æÄ£


@adonisjs/bodyparser <= 10.1.1
@adonisjs/bodyparser <= 11.0.0-next.5


Èý¡¢Çå¾²²½·¥


3.1 Éý¼¶°æ±¾


¹Ù·½ÒÑÐû²¼ÐÞ¸´²¹¶¡£¡£¡£ ¡£¡£¡£¬£¬£¬£¬ÒÔÐÞ¸´¸ÃÎó²î¡£¡£¡£ ¡£¡£¡£
@adonisjs/bodyparser >= 10.1.2
@adonisjs/bodyparser >= 11.0.0-next.6


ÏÂÔØÁ´½Ó£ºhttps://github.com/adonisjs/bodyparser/releases/


3.2 ÔÝʱ²½·¥


ÔÝÎÞ¡£¡£¡£ ¡£¡£¡£


3.3 ͨÓý¨Òé


? °´ÆÚ¸üÐÂϵͳ²¹¶¡£¡£¡£ ¡£¡£¡£¬£¬£¬£¬ïÔ̭ϵͳÎó²î£¬£¬£¬£¬ÌáÉýЧÀÍÆ÷µÄÇå¾²ÐÔ¡£¡£¡£ ¡£¡£¡£
ÔöǿϵͳºÍÍøÂçµÄ»á¼û¿ØÖÆ£¬£¬£¬£¬Ð޸ķÀ»ðǽսÂÔ£¬£¬£¬£¬¹Ø±Õ·ÇÐëÒªµÄÓ¦Óö˿ڻòЧÀÍ£¬£¬£¬£¬ïÔÌ­½«Î£ÏÕЧÀÍ£¨ÈçSSH¡¢RDPµÈ£©Ì»Â¶µ½¹«Íø£¬£¬£¬£¬ïÔÌ­¹¥»÷Ãæ¡£¡£¡£ ¡£¡£¡£
ʹÓÃÆóÒµ¼¶Çå¾²²úÆ·£¬£¬£¬£¬ÌáÉýÆóÒµµÄÍøÂçÇå¾²ÐÔÄÜ¡£¡£¡£ ¡£¡£¡£
ÔöǿϵͳÓû§ºÍȨÏÞÖÎÀí£¬£¬£¬£¬ÆôÓöàÒòËØÈÏÖ¤»úÖÆºÍ×îСȨÏÞÔ­Ôò£¬£¬£¬£¬Óû§ºÍÈí¼þȨÏÞÓ¦¼á³ÖÔÚ×îµÍÏÞ¶È¡£¡£¡£ ¡£¡£¡£
ÆôÓÃÇ¿ÃÜÂëÕ½ÂÔ²¢ÉèÖÃΪ°´ÆÚÐ޸ġ£¡£¡£ ¡£¡£¡£


3.4 ²Î¿¼Á´½Ó


https://github.com/adonisjs/core/security/advisories/GHSA-gvq6-hvvp-h34h/
https://nvd.nist.gov/vuln/detail/CVE-2026-21440