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