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