aiohttpĿ¼´©Ô½·ì϶£¨CVE-2024-23334£©·ÖÎö

°ä²¼¹¦·ò 2024-04-01

Ò»¡¢·ì϶¸ÅÊö


aiohtp Êǹ¹½¨ÓÚ Python l/0 ¿ò¼Ü AsyncI0 Ö®ÉϵĿªÔ´¿â£¬ÓÃÓÚ´¦ÖÃÎÞÐè»ùÓÚ´«Í³Ïß³ÌÍøÂçµÄ´óÁ¿²¢·¢HTTPÒªÇó¡£aiohttpÖ§³ÖHTTP¿Í»§¶Ë¡¢HTTP·þÎñ¶Ë¡¢WebSocket¿Í»§¶Ë¡¢WebSocket·þÎñ¶Ë¡¢·þÎñ¶ËÖÐÑë¼þµÈ¡£aiohttp±»¿í·ºÊ¹Óã¬ÔÚÍøÂçÖÐÓдóÁ¿»ùÓڸÿò¼Ü¿ª·¢µÄÔÚÏßϵͳ¡£

±¦ÔËÀ³¹Ù·½ÍøÕ¾ADLab×êÑÐÔ±ÔÚ·ì϶µý±¨¸ú×ÙÖз¢ÏÖÁËaiohttpĿ¼±éÀú·ì϶£¨CVE-2024-23334£©£¬²¢¶ÔÆä½øÐÐÁËÉî¿Ì·ÖÎöºÍÑéÖ¤¡£


¶þ¡¢Ó°Ïì°æ±¾


ÊÜÓ°Ïì°æ±¾£º<3.9.2£¬ÇëÓйØÓû§¾¡¿ìÉý¼¶µ½3.9.2¼°ÒÔÉϰ汾¡£


Èý¡¢·ì϶·ÖÎö


¸Ã·ì϶µÄ¹Ø¼üÐÅÏ¢ÈçÏÂ[1]£º

aiohttp is an asynchronous HTTP client/server framework for asyncio and Python. When using aiohttp as a web server and configuring static routes, it is necessary to specify the root path for static files. Additionally, the option 'follow_symlinks' can be used to determine whether to follow symbolic links outside the static root directory. When 'follow_symlinks' is set to True, there is no validation to check if reading a file is within the root directory. This can lead to directory traversal vulnerabilities, resulting in unauthorized access to arbitrary files on the system, even when symlinks are not present. Disabling follow_symlinks and using a reverse proxy are encouraged mitigations. Version 3.9.2 fixes this issue.


ƾ¾Ý¹Ø¼üÐÅÏ¢£¬¶¨Î»µ½¿ª·¢ÎĵµµÄ×¢Ã÷[2]£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ƾ¾ÝÎĵµÃèÊö£¬follow_symlinksÊÇÒ»¸öÉè¼ÆÉÏÓÃÓڷdzö²ú»·¾³µÄÖ°ÄÜ£¬²¢ÇÒÒÑÔÚÎĵµÖÐÃ÷È·ÌáÐÑÆôÓøÃÖ°ÄÜÊÇÒ»¸ö°²È«·çÏÕ¡£


±àдÈçϵÄʾÀý´úÂ룬²âÊÔfollow_symlinksµÄÖ°ÄÜ£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ÔÚstaticĿ¼Ï´´½¨·ûºÅÁ´½Ód£¬Ö¸ÏòÆäËüĿ¼d:\test£¨¸ÃĿ¼Ï´æÔÚ²âÊÔÎļþ123.txt£©¡£


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ÒÔfollow_symlink=fasleµÄģʽÆô¶¯²âÊÔwebserver£¬½Ó¼ûstatic/d/123.txtµÄÁ˾ÖÈçÏÂËùʾ£¨ÌáÐÑÕÒ²»µ½Îļþ£©£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ÒÔfollow_symlink=trueµÄģʽÆô¶¯²âÊÔwebserver£¬½Ó¼ûstatic/d/123.txtµÄÁ˾ÖÈçÏÂËùʾ£¨³É¹¦¶ÁÈ¡ÎļþÄÚÈÝ£©£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ÏÔÈ»£¬Æ¾¾ÝÎĵµµÄÃèÊö£¬ÈôÊÇfollow_symlink=trueÇÒ´æÔÚ·ûºÅÁ´½Ó£¬Á˾־ÍÊÇ·¨Ê½µÄÕý³£Ô¤ÆÚÖ°ÄÜ¡£ÄÇô£¬¸ÃÖ°ÄÜÊÇÈôºÎ±»È϶¨³É·ì϶ £¿


·ì϶µÄ¹Ø¼üÐÅÏ¢[1]ÖÐÓÐÒ»¾ä³ÁÒªÃèÊö£º·ì϶²»ÒÀÀµÓÚ·ûºÅÁ´½ÓµÄ´æÔÚÐÔ¡£µ«ÊÇ£¬ÔÚÒªÇóõè¾¶ÖÐʹÓò»´æÔڵķûºÅÁ´½Ó£¬µ×²ãÓÖÈôºÎÄܽӼûµ½Ö¸±êÎļþ¡£


¾­¹ý¶ÈÎö£¬·¢Ïֵײ㴦ÖÃÒªÇóµÄ¹Ø¼üº¯ÊýÈçÏ£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


Ê×ÏÈ£¬»ñȡҪÇóÎļþÃû£¨filename£©¡£ÒÔ GET /static/d/123.txtΪÀý£¬filename¾ÍÊÇd/123.txt¡£


¶øºó£¬°Ñfilenameת»»ÎªPath¶ÔÏ󣬲¢¼ì²â¸Ã¶ÔÏóÊÇ·ñ´æÔÚanchorÊôÐÔ¡£ÈôÊÇ´æÔÚ£¬Ôò»Ø¾ø½Ó¼û¡£ÔÚwindowsƽ̨ÉÏ£¬anchor¶ÔÏó¾ÍÊÇÅÌ·û£¨ºÃ±Èd:\£©¡£Òò¶ø£¬´Ë´¦´æÔÚ°²È«¼ì²â£¬¼´²»ÔÊÐí¿çÅÌ·û½Ó¼û¡£ºÃ±ÈGET /static/d:\test\123.txt£¬»á±»ÊÓ×÷·¸·¨ÒªÇó¶ø»Ø¾ø£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ÔÙ¶øºó£¬°ÑstaticĿ¼µÄPath¶ÔÏóºÍfilenameµÄPath¶ÔÏó×öÆ´½Ó£¬ÐγÉÐÂÎļþõè¾¶filepath¡£×îºó£¬¶ÁÈ¡filepathµÄÊý¾Ý£¬²¢·µ»Ø¸ø¿Í»§¶Ë¡£


ÏÔÈ»£¬ÈôÊÇfilenameÔ̺¬²»´æÔڵķûºÅÁ´½Ó£¬µ«ÄܽӼûµ½Ö¸±êÎļþ£¬ÄÇ×¢Ã÷¶ÔÏóÆ´½Ó²úÉúÁË·ÇÔ¤ÆÚµÄÁ˾Ö¡£ÓÉÓÚPath¶ÔÏóÊdz߶ȵÄpythonÀֱ࣬½Óµ¥¶À½øÐвâÊÔ¡£


£¨1£©É趨directory=c:\test , filename = d:\test\123.txt£¬Æ´½Ó´úÂëºÍÁ˾ÖÈçÏÂ:


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


Æ´½ÓÁ˾ÖÖ¸ÏòÖ¸±êÎļþd:\test\123.txt£¬µ«ÊÇfnameÔ̺¬anchor£¬ÎÞ·¨Í¨¹ýÇ°ÃæµÄfilename.anchor²é³­¡£


£¨2£©É趨directory=c:\test , filename = ..\d:\test\123.txt£¬Æ´½Ó´úÂëºÍÔËÐÐÁ˾ÖÈçÏ£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


Æ´½ÓÁ˾ֶÁÈ¡µ½Ö¸±êÎļþ£¬ÇÒfname²»Ô̺¬anchor£¬ÄÜͨ¹ýfilename.anchor²é³­¡£


£¨3£©É趨directory=c:\test , filename = ..\..\d:\test\123.txt£¬Æ´½Ó´úÂëºÍÔËÐÐÁ˾ÖÈçÏ£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


Æ´½ÓÁ˾ÖÒ²¶ÁÈ¡µ½ÁËÖ¸±êÎļþ£¬ÇÒfname²»Ô̺¬anchor£¬ÄÜfilename.anchor²é³­¡£


Òò¶ø£¬Ö»ÓÐÔÚfilename֮ǰ¼ÓÉÏ..\¾ÍÄÜÖ±½ÓÒýÈëÅÌ·û£¬Î¥±³Ô­Ê¼Ö°ÄÜÉè¼ÆÖбØÒª·ûºÅÁ´½Ó´æÔÚµÄÏÞ¶È£¬´Ó¶øÐγÉÁËÄܹ»¶ÁÈ¡´ÅÅÌÉÏËÁÒâÎļþµÄ°²È«·ì϶¡£


ËÄ¡¢²¹¶¡·ÖÎö


²¹¶¡¹Ø¼ü´úÂëÈçÏ£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


²¹¶¡µÄÖ÷Ìâ˼ÔìÊÇ£ºõè¾¶Æ´½Ó³Éunresolved_pathºó£¬Ê×ÏÈŲÓÃnormpath´¦ÖÃunresolved_pathÀ´ÐγÉnormalized_path£¬¶øºóÅж¨normalized_pathÊÇ·ñλÓÚ¾²Ì¬Ä¿Â¼_directory֮ϡ£


µ¥¶À²âÊÔ²¹¶¡»úÔìµÄ´úÂëºÍÁ˾ÖÈçÏ£º


±¦ÔËÀ³¡¤(ÖйúÇø)×îйٷ½ÍøÕ¾


ÏÔÈ»£¬ÓÉÓÚÆ´½ÓºóµÄõè¾¶²»ÊÇstaticĿ¼µÄ×ÓĿ¼£¬ËùÒÔ´¥·¢ÁËÒì³££¬µ¼ÖºóÐø´úÂë²»ÔÙ¶Áȡƴ½Óºóõ辶ϵÄÎļþ£¬´Ó¶øµ¼ÖÂÁ˸÷ì϶²»ÔÙ´æÔÚ¡£


²¹¶¡²»Ó°ÏìaiohttpµÄ·ûºÅÏνÓÖ§³Ö£¬ÓÉÓÚ·ûºÅÁ´½ÓÎļþ±ØÐë´æÔÚÓÚstaticĿ¼֮Ï¡£Ê¹Ó÷ûºÅÁ´½ÓÎļþÀ´´¦ÖÃstatic×ÊÔ´×ÔÉí¾ÍÊÇÒ»¸öDZÔڵݲȫ·çÏÕ£¬¿ª·¢ÕßÈÔ±ØÒªÒýÆð×ã¹»µÄÆ÷³Á£¬ÉóÉ÷ʹÓøÃÖ°ÄÜ¡£