scp ¿Í»§¶Ë¶à¸öÎó²îÇ徲ͨ¸æ

Ðû²¼Ê±¼ä 2019-01-16

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


CVE±àºÅ£ºCVE-2018-20685  Î£ÏÕ¼¶±ð£º¸ßΣ   CVSS·ÖÖµ£º³§ÉÌ×ÔÆÀ£º7.5£¬¹Ù·½Î´ÆÀ¶¨

CVE±àºÅ£ºCVE-2019-6111   Î£ÏÕ¼¶±ð£ºÖÐΣ   CVSS·ÖÖµ£º³§ÉÌ×ÔÆÀ£º5.3£¬¹Ù·½Î´ÆÀ¶¨

CVE±àºÅ£ºCVE-2018-20684  Î£ÏÕ¼¶±ð£ºÖÐΣ   CVSS·ÖÖµ£º³§ÉÌ×ÔÆÀ£º5.3£¬¹Ù·½Î´ÆÀ¶¨

CVE±àºÅ£ºCVE-2019-6109   Î£ÏÕ¼¶±ð£ºµÍΣ   CVSS·ÖÖµ£º³§ÉÌ×ÔÆÀ£º3.1£¬¹Ù·½Î´ÆÀ¶¨

CVE±àºÅ£ºCVE-2019-6110   Î£ÏÕ¼¶±ð£ºµÍΣ   CVSS·ÖÖµ£º³§ÉÌ×ÔÆÀ£º3.1£¬¹Ù·½Î´ÆÀ¶¨


Ó°Ïì¹æÄ£


ÊÜÓ°Ïì°æ±¾£º

OpenSSH scp <=7.9

WinSCP scp mode <=5.13


Îó²î¸ÅÊö


scp¿Í»§¶Ë±£´æ¶à¸öÎó²î£¬ÆäÖÐCVE-2019-6111¡¢CVE-2018-20684¿ÉÒÔ×·Ëݵ½1983Äê ¡£


OpenSSHÊÇÒ»Ì×ÓÃÓÚÇå¾²»á¼ûÔ¶³ÌÅÌËã»úµÄÅþÁ¬¹¤¾ß£¬»òÔÚÅÌËã»úÖ®¼ä´«ËÍÎļþ ¡£WinSCPÊÇÒ»¸öWindowsÇéÐÎÏÂʹÓÃSSHµÄ¿ªÔ´Í¼Ðλ¯SFTP¿Í»§¶Ë£¬Í¬Ê±Ö§³ÖSCPЭÒ飬ËüµÄÖ÷Òª¹¦Ð§¾ÍÊÇÔÚÍâµØÓëÔ¶³ÌÅÌËã»ú¼äÇå¾²µÄ¸´ÖÆÎļþ ¡£scp ClientÊÇËüÃÇÖеÄÒ»¸öSCP¿Í»§¶Ë£¬±£´æÒÔÏÂÎó²î£º


CVE-2018-20685 scp¿Í»§¶Ë²»×¼È·µÄĿ¼Ãû³ÆÑéÖ¤Îó²î


scp¿Í»§¶ËµÄscp.cÎļþ±£´æÇå¾²Îó²î ¡£Ô¶³Ì¹¥»÷Õ߿ɽèÖú.ÎļþÃû»ò¿ÕÎļþÃû£¬Ê¹ÓøÃÎó²îÈÆ¹ý»á¼ûÏÞÖÆ ¡£


CVE-2019-6111 scp¿Í»§¶ËȱÉÙÊÕµ½µÄ¹¤Ç©×Ö³ÆÑéÖ¤Îó²î


ÓÉÓÚscpʵÏÖÔ´×Ô1983 rcp£¬·þÎñÆ÷Ñ¡ÔñÄĸöÎļþ/Ŀ¼±»·¢Ë͵½¿Í»§¶Ë ¡£¿ÉÊÇ£¬scp¿Í»§¶ËÖ»Ö´ÐмòªÑéÖ¤·µ»ØµÄ¹¤Ç©×ֳƣ¨½ö×èֹĿ¼±éÀú¹¥»÷£© ¡£¶ñÒâscp·þÎñÆ÷¿ÉÒÔÁýÕÖscp¿Í»§¶ËÄ¿µÄĿ¼ÖеÄí§ÒâÎļþ ¡£ÈôÊÇÖ´Ðеݹé²Ù×÷£¨-r£©£¬Ôò·þÎñÆ÷ͬÑù¿ÉÒÔ²Ù×÷×ÓĿ¼ ¡£


WinSCPÖеÄÏàͬÎó²î³ÆÎªCVE-2018-20684 ¡£


CVE-2019-6109 ͨ¹ý¹¤Ç©×ֳƾÙÐÐscp¿Í»§¶ËÓÕÆ­Îó²î


ÓÉÓÚ½ø¶ÈÏÔʾÖÐȱÉÙ×Ö·û±àÂ룬Òò´Ë¿ÉÒÔʹÓù¤Ç©×Ö³ÆÊ¹Óÿͻ§¶ËÊä³ö£¬ÀýÈçʹÓÃANSI´úÂëÒþ²ØÆäËûÕýÔÚ´«ÊäµÄÎļþ ¡£


CVE-2019-6110 ͨ¹ýstderr¾ÙÐÐscp¿Í»§¶ËÓÕÆ­Îó²î


ÓÉÓÚ½ÓÊܲ¢ÏÔʾÀ´×Ôscp·þÎñÆ÷µÄí§ÒâstderrÊä³ö£¬¶ñÒâ·þÎñÆ÷¿ÉÒÔʹÓÿͻ§¶ËÊä³ö£¬ÀýÈçʹÓÃANSI´úÂëÒþ²ØÕýÔÚ´«ÊäµÄÆäËûÎļþ ¡£


Îó²îÑéÖ¤


ÔÝÎÞPOC/EXP ¡£


ÐÞ¸´½¨Òé


OpenSSH£º

1.       ÈôÊÇ¿ÉÒÔÇл»³Ésftp ¡£

2.       ÏÖÔÚ³§ÉÌÒÑÐû²¼Éý¼¶²¹¶¡ÒÔÐÞ¸´Îó²î£¬https://sintonen.fi/advisories/scp-name-validat

or.patch.

WinSCP£º

Éý¼¶µ½WinSCP 5.14»ò¸ü¸ß°æ±¾ ¡£


²Î¿¼Á´½Ó


https://sintonen.fi/advisories/scp-client-multiple-vulnerabilities.txt

https://github.com/openssh/openssh-portable/commit/6010c0303a422a9c5fa8860c061bf7105eb7f8b2

https://cvsweb.openbsd.org/cgi-bin/cvsweb/src/usr.bin/ssh/scp.c.diff?r1=1.197&r2=1.198&f=h