ãŠãŒã¶ãŒãšã¡ãŒã«ã€ã³ã¿ãŒãã§ãŒã¹éã®æ¥ç¶ã®æå·åã¯ã倧èŠæš¡ãªãµãŒãã¹ã§ã¯ãã§ã«éåžžã«äžè¬çã§ãããšããäºå®ã«ãããããããã¡ãŒã«ã·ã¹ãã éã®éä¿¡ã¯ãã°ãã°ä¿è·ãããªããªããŸããã ãŸããéä¿¡ã®ã»ãã¥ãªãã£ã¯ç§ãã¡ã«ãšã£ãŠéåžžã«éèŠãªãã®ã§ãïŒãã ããå¹³åçãªãŠãŒã¶ãŒã«ã¯ããŸãç®ç«ã¡ãŸããïŒã

ç 究è ã¯ãã€ã³ã¿ãŒãããæè¡è ã®ç¥èªã«å¯Ÿããçã®æã®çç±ããŸã èŠã€ããŠããŸããã ARPANET以éããã¹ãŠã®ãããã¯ãŒã¯ããããã³ã«ãæšæºãªã©ã ç¥èªãšåŒã°ããããšã奜ãã ãã®åçŽã§ããããããåèªåœ¢ææ¹æ³ã¯ããIETFãã SSHFPã§RSAãDSAãããã³ECDSAã䜿çšããSHA-256ã®äœ¿çšã«é¢ããCZ.NICã«ããRFC6594ãå ¬ââéããŸããããšãã圢åŒã®æã«ã€ãªãããŸãã ã芧ã®ãšãããæå·åã«ã¯ãã®ãããªç¥èªãç¹ã«å€ããããŸãã
SSLããã³TLSãšã¯äœã§ããïŒ
åäžçŽã®90幎代ã«ãåŠè¡ç°å¢ããã®ããããçš®é¡ã®èå³æ·±ãã¢ã€ãã¢ãçŸå®ã«å ·äœåããããã€ã³ãã¥ããŒã¿ãŒãã®1ã€ãNetscapeã§ããã æšå¹Žã®åãã«ãæ¥ç¶ã®æå·åã®å¯èœæ§ã«æ°ã¥ãããããã³ã«ãå ¬éããSecure Sockets LayerïŒSSLïŒãšåŒãã ã®ã¯åœŒå¥³ã®åŸæ¥å¡ã§ããã æåã®å ¬éããŒãžã§ã³ã¯SSL v2ã§ãããããã«ããå€ãã®è匱æ§ãããã«èŠã€ãããŸãã ã ãã®åŸãçŸåšå©çšå¯èœãªæåŸã®SSL v3ãç¶ããŸããã Netscape ã®å ã®èª¬æã¯ãAOLã«ããNetscapeã®åžåã®éã«å¿åŽã«é¥ããŸãããã2011幎ã«RFC6101ã®åœ¢åŒã§ã¹ããŒãªãŒã®ããã«å ¬éãããŸãã ã
ãã®åŸãæåã®ç¡æã®SSLå®è£ ãç»å ŽããŸããã æ奜家ã®Eric Youngã¯ã BSDã©ã€ã¯ãªã©ã€ã»ã³ã¹ã®äžã§SSLeayã©ã€ãã©ãªïŒä»åã¯ããŒã ã®ç¥ç§°ïŒSSL + Eric A. YoungïŒã®å ¬éãéå§ããŸããã SSLeayã¯ãæ°å¹ŽåŸã«ã¯ãã¹ãŠã®å°é家ã«ç¥ãããŠããOpenSSLã©ã€ãã©ãªã«å€ãããŸãã
SSL v2ããã³v3ã«ã€ããŠç¥ã£ãŠããã¹ãéèŠãªããšã¯äœã§ããïŒ ãŸãããããã®ãããã³ã«ã¯ãä¿¡é Œæ§ã®é«ãé ä¿¡ãšæ¥ç¶ïŒTCPãªã©ïŒãåãããã©ã³ã¹ããŒããããã³ã«äžã§åäœããããã«èšèšãããŠããŸãã 第äºã«ãSSL v2ã¯ãã¯ã䜿çšã§ããªããªããŸãããå ¬åŒã«ã¯è匱ããããšèŠãªãããŠãããçŸåšã®ç°å¢ã§ã¯ã»ãã¥ãªãã£ã®é¯èŠãäžããã ãã§ãã
SSL v3ã«åºã¥ããŠã IETFå ã®ç§åŠè ãšãšã³ãžãã¢ã®ããŒã ã¯ããã©ã³ã¹ããŒãå±€ã»ãã¥ãªãã£ïŒ TLSïŒãããã³ã«ãäœæããŸããã å®éãTLS v1.0ã¯SSL v3ã®å°ããªïŒãã ãäºææ§ã®ãªãïŒåèšèšã§ããããã¹ãŠã®æ©èœãå«ãŸãã詳现ãè¿œå ãããŠããŸãã
90幎代ã®çµãããšãŒãã®å§ãŸãã¯ãHTTPSã®åºç¯ãªäœ¿çšïŒããã³ãããã¯åã«HTTP over SSL / TLS-æå·åHTTPïŒã«ãã£ãŠããŒã¯ããããã®çµæã äž¡æ¹ã®è²ã®åžœåã§ã³ã³ãã¥ãŒã¿ãŒã»ãã¥ãªãã£ã®å°é家ã«ãã£ãŠãããã®ãããã³ã«ã«çŽ°å¿ã®æ³šæãæãããŸããã ãã®çµæãCBCã¢ãŒãã§ãããã¯æå·åã¢ã«ãŽãªãºã ã䜿çšããŠSSL v3ãŸãã¯TLS 1.0ã䜿çšããå ŽåïŒããã³SSLã§ä»ã®ãããã¯ã¢ã«ãŽãªãºã ã¢ãŒãã䜿çšãããªãã£ãå ŽåïŒã ãã¹ãŠã®ã¯ã©ã¹ã®è匱æ§ãçºèŠãããŸããã 2006幎-ãã§ã«7幎åŸ-TLS 1.1ã®æŽæ°ããŒãžã§ã³ããªãªãŒã¹ããããããã®è匱æ§ãæé€ãããŸããã ãããã2011幎ãŸã§ãTLS 1.1ã䜿çšãããã©ãŠã¶ã«å¯Ÿãã倧èŠæš¡ãªæ»æãBEASTãšåŒã°ãã倧èŠæš¡ãªæ»æãã€ã³ã¿ãŒãããã«ããããããšãããšã³ãžãã¢ã¯TLS 1.1ã®å®è£ ãæ¥ãã§ããŸããã§ããã ããã€ãã®æŸèæãããã«çºæããïŒããšãã°ãã¹ããªãŒã æå·ãžã®åãæ¿ãïŒããã¹ãŠãTLS 1.1+ã«ã¢ããã°ã¬ãŒãããããã®åªå é äœãäžãããŸããã
2008幎ã«ãTLSã®ææ°ããŒãžã§ã³1.2ã®ä»æ§ããªãªãŒã¹ãããŸããã å€ãã®ã€ãããŒã·ã§ã³ãç»å ŽããŸããã ãŸãã AESæå·åã¢ã«ãŽãªãºã ã䜿çšããæ©èœãå¿ é ã«ãªããCBC- GCMã«å ããŠæ°ããæå·åã¢ãŒããç»å ŽããŸããã 第äºã«ãã¬ã¬ã·ãŒDESããã³IDEAã¢ã«ãŽãªãºã ã®ãµããŒãã¯é€å€ãããŸããã 第äžã«ããããã³ã«ã¯MD5ããã·ã¥ã¢ã«ãŽãªãºã ã«åºã¥ãHMACã®äœ¿çšãæŸæ£ããããå®å®ããSHA256ããã³SHA384ã«åãæ¿ããŸããã 4çªç®ã«ãTLSæ¡åŒµã¡ã«ããºã ãç»å ŽããŸãããããã«ããããããã³ã«ãå®å šã«åèšèšããããšãªããæ°ããæ©èœãå«ããããšãã§ããŸãã ãããã®æ¡åŒµæ©èœã®1ã€ã¯SNIã§ã ãããã¯ãYandexãµãŒãã¹ã§ç©æ¥µçã«äœ¿çšãããŠããŸãã æåŸã«ããã¹ãŠã®é©æ°ã圹ã«ç«ããªãããã«ããããã³ã«ã§ã¯SSLv3ãžã®ããŠã³ã°ã¬ãŒãã®å¯èœæ§ã¯å»æ¢ãããæšå¥šãããŠããŸããã
èŠçŽãããšã
- SSLã¯ãTCPãä»ããå®å šãªæ¥ç¶ãããã³ã«ã§ãã æ°ããSSLããŒãžã§ã³ã¯ãããŸããã TLSâããã¯æ°ããSSLã§ãããæ°ããããŒãžã§ã³çªå·ãä»ããããŠããŸãã
- å€ãSSL v2ããããŸãã 䜿çšã§ããŸãã-ãµããŒããããŠããå Žåã¯ãç¡å¹ã«ããå¿ èŠããããŸãã SSL v3ããããããã¯ã©ãã§ãé·å¹Žã«ããã£ãŠãµããŒããããŠããŸãã ããããã»ãã¥ãªãã£ã«æªåœ±é¿ãåãŒãå¯èœæ§ã®ããæ¬ é¥ãèŠã€ãããŸããã TLS v1.0ããããSSL v3ã®è匱æ§ãä¿æããŠãããã€ã³ã©ã€ã³æå·åã¢ã«ãŽãªãºã RC4 ïŒçè«çã«è匱ã§ãããšå¥ã«èããããïŒã§ã®ã¿äœ¿çšããããšããå§ãããŸãã ãããã£ãŠãTLS v1.1ãŸãã¯v1.2ã䜿çšããŠãRC4æå·ãç¡å¹ã«ããããšããå§ãããŸãã
ã¡ãŒã«ãããã³ã«
HTTPã¯ãé»åã¡ãŒã«ãéä¿¡ããããã®äž»èŠãªãŠãŒã¶ãŒãããã³ã«ã§ãããšèªä¿¡ãæã£ãŠèšããŸãã ããã¯ç°åžžã«èããããããããŸãããã倧å€æ°ã®ãŠãŒã¶ãŒã¯2013幎ã«ã¡ãŒã«ãèªãã§éä¿¡ããŸãã

ã¡ãŒã«ããã°ã©ã ã¯ãèæ¯ã«è²ãããŠããŸããããŸã åºã䜿çšãããŠããã3ã€ã®ãããã³ã«ã§åäœããŸããå€ãPOP3ãå°ãæ°ããIMAPããŠãããŒãµã«SMTPã§ãã 以å ãPOP3ãšIMAPã®æŽå²ã«ã€ããŠå°ã話ãããŸãããã SMTPã«ã€ããŠå°ãè¿œå ããŸãã
é»åã¡ãŒã«ã¯ãæåã®ãã©ãŒã©ãããããã³ã³ãã¥ãŒã¿ãŒãããã¯ãŒã¯ãšåŒã°ããŠããŸãã çŸä»£ã®SMTPïŒSimple Mail Transfer ProtocolïŒã®ã«ãŒãã¯ãç±³åœåœé²ç·çããã®è³éã§ã¢ã¡ãªã«ã®å€§åŠã®ã³ã³ãã¥ãŒã¿ãŒéã§ãã¡ã€ã«ã転éããTCP / IP以åã®æ代ã«ãARPANETã«æ·±ãå ¥ã蟌ã¿ãŸããã ãããã¯ãæå·åã ãã§ãªããåçŽãªèªèšŒãããå¿ èŠãšãããªããçŽ æŽã§åºç¯ã«ãããçžäºä¿¡é Œã®çŽ æŽãããæ代ã§ããã ãšããã§ãæ°å¹ŽåŸã«ç§ãã¡ã«äœãèµ·ãã£ãã®ãã¯ãããªãèªèº«ã®ã¹ãã ãã©ã«ãã§èŠãããšãã§ããŸãã
ã€ã³ã¿ãŒãããçšSMTPã®æåã®ããŒãžã§ã³ïŒå€§æåïŒïŒãåç §ããŠãã ããã1981幎ã®çµããã«RFC 788ã§æå®ãããŸãã ã ããã§ããããã¯ARPANETã§ã®é»åã¡ãŒã«éçºã®10幎以äžã®çµæã§ããã ãããŠã1999幎ã®ã»ãŒ20幎åŸã«ãããããèªèšŒã®å ¬åŒæšæºãã€ãŸãSMTPã§ã®ãã°ã€ã³ãšãã¹ã¯ãŒããç»å ŽããŸããã ãããŸã§ãSMTPçµç±ã§ã¡ãŒã«ãéä¿¡ããããšã¯ã誰ãšã§ã誰ã§ãæ¥ç¶ããçŽåŸã«å¯èœã§ããã ãã¡ããããã®ã¢ãŒãã¯ãå€æ°ã®åžæãæã€ãããã¯ãŒã¯äžã®ãµãŒããŒééä¿¡ã«é©ããŠããŸããããã®å Žåããã¹ãã¯ä»ã®èª°ãã®ã¡ãŒã«ã®ãªã¬ãŒãšããŠæ©èœã§ããŸãã ããããèªèšŒãªãã®æåã®éä¿¡ããããããµãããã·ã§ã³ã¯ãã¹ãã ã®åºçŸã«ã€ãªãããSMTP SMTPã®çºæã«ã€ãªãããŸããã ãšããã§ãæã®äººã¯ãPOP3ãSMTPã®èªèšŒæŸèæãšããŠäœ¿çšãããPOP3 before SMTPãã¢ãŒãããŸã èŠããŠããŸãã
ãããã³ã«ã«ãã¹ã¯ãŒãã衚瀺ããããšããã«ãæå·åã«ã€ããŠããã«èãå§ããŸãã 2002幎ã«ããªãŒãã³SMTPã»ãã·ã§ã³ã®TLSã¢ãŒããžã®ã¢ããã°ã¬ãŒãããµããŒãããæšæºâRFC3207ããªãªãŒã¹ãããŸãã ã ããã¯ãäºå®äžã®ç¶æ³ãä¿®æ£ããã³æ¹åããè©Šã¿ã§ããããã®ãšããŸã§ã«ãå¥ã®ããŒã465ã§ã®SMTPæå·åãæ°å¹Žé䜿çšãããŠããŸããã
STARTTLSæäœã¹ããŒã ã¯ç¹ã«éèŠã§ãã ããã¯ãä»»æã®ããã¹ããããã³ã«ã®æ±çšæ¡åŒµæ©èœã§ãã å®éã«ã¯ãSMTPãIMAP / POP3ãããã³FTPçšã«å°ãé åžãããŠããŸãã

ãã§ã«ç¢ºç«ããããªãŒãã³æ¥ç¶ã®ã¯ã©ã€ã¢ã³ããšãµãŒããŒãäž¡åŽã®ããŒã¿äŒéãæå·åããæ©äŒãšåžæãããããšãç解ããç¬éã«ãã¯ã©ã€ã¢ã³ãã¯STARTTLSã³ãã³ããäžããŠããã«TLSãã³ãã·ã§ã€ã¯ãéå§ããŸãã

æå·åãéå§ããåã«TLSã®çžäºãµããŒãã確èªããæ¹æ³ã®ã¿ããã¢ããªã±ãŒã·ã§ã³ãããã³ã«ã«äŸåããŸãã SMTPã®å Žåãããã¯ESMTPæ¡åŒµã¡ã«ããºã ãä»ããŠè¡ãããŸããããã«ã¯è©³çŽ°ããããŸãã

æšæºããŒãïŒå€ãã®å Žåå¿ããããŠãã25ããã³2çªç®ã®587ãæãåºããŠãã ããïŒãŸãã¯ããŒã465ã§ã®STARTTLSãä»ããSMTPæå·åã¯ãããã«äººæ°ãåãå§ããŸããã TLSã¯å€ãã®ããšãå¯èœã«ããŸãã蚌ææžèªèšŒãšãµãŒããŒèªèšŒâãããã¯ãã¹ãŠèå³æ·±ããå¿ èŠã§ããããŸã§å©çšã§ããªãã£ãæ©èœã§ãã çŸåšãæå·åãããæ¥ç¶ãä»ããŠãŠãŒã¶ãŒããã®ã¡ãŒã«ãåãä»ããªãã¡ãŒã«ã·ã¹ãã ã¯ãªãããã§ãã ãã1ã€ã®ããšã¯ããµãŒããŒééä¿¡ã§ãã
SMTPã¯åãªãé»åã¡ãŒã«ã®éŠ¬ã§ã¯ãªããåé ã®éŠ¬ã§ããããŸãã
ããŸããŸãªã¡ãŒã«ã·ã¹ãã ã®ãµãŒããŒéã§ã®æçŽã®ããåãããã¹ãŠSMTPãä»ããŠè¡ãããŸãã ãã¡ããããã¹ã¯ãŒãèªèšŒã¯ãããŸããâãã®ä»£ããã«ãã¢ããªã±ãŒã·ã§ã³ã¬ãã«ã§ã®æçŽã®åä¿¡è ã®ã¢ãã¬ã¹ã®ç¢ºèªã䜿çšãããŸãã ååšããªãå Žåã¯ããªãŒãã³ãªã¬ãŒã§ããããšãå€æããŸããããã«ãããäžçäžã®ã¹ãã 察çã·ã¹ãã ãåŠå®çãªè©å€ã§çœ°ããããããšã«ãªããŸãã éåžžãããã«ã¯æå·åã¯ãããŸããã ããã«ã¯ããã€ãã®çç±ããããŸãã 第äžã«ãã¡ãŒã«ã·ã¹ãã ã®ãµãŒããŒéã®éä¿¡ãã£ãã«èªäœã¯éåžžã«å®å šã§ãããšèããããŠããŸãã å®éããµãŒããŒéã§è»¢éããå Žåãéåžžãæåã¯ãã©ã¹ããã€ã«ããŸã§å±ããŸãããéåžžããã©ã¹ããã€ã«ãã§ã¯ãå°ããªãã«ãžã¥ã¢ã«ãªããã©ãã£ãã¯ã€ã³ã¿ãŒã»ãããçºçããŸãã 第äºã«ããã®éä¿¡ã¯éåæã§é察話çã§ãããããæ¥ç¶ãåãåã£ãåœäºè ã®èšŒææžã®éåãŸãã¯æéåãã®å Žåã«äœããã¹ããã人ã«æ確ã«ããæ¹æ³ã¯ãããŸããã
ãããããããã®è°è«ã¯ãã¹ãŠåãå ¥ãããããã®ã§ãã åä¿¡ãµãŒããŒã¯ã倧èŠæš¡ãªå®å šãªããŒã¿ã»ã³ã¿ãŒã®ã©ãã¯å ã§ã¯ãªããã©ãã«ã§ãããå¯èœæ§ããããŸãã äžçäžã®æ¿åºæ©é¢ã¯ããã¹ãŠã®éä¿¡ãã£ãã«ã§çèŽããã°ã©ã ãéå§ããŠããŸãã 蚌ææžã®æ€èšŒã¯åœ¹ç«ã€å ŽåããããŸãããæ å ±ã®è»¢éãä¿è·ããããã«ã¯å¿ èŠãããŸããã ãããã£ãŠãå€ãã®å Žåããã¹ãŠã®æ¹æ³ã§æå·åãããæåã衚瀺ãããŸã-ãŠãŒã¶ãŒã®ãã©ãŠã¶ããHTTPSãä»ããŠã¡ãŒã«ã·ã¹ãã ãµãŒããŒãåä¿¡è ã®ãµãŒããŒãSMTP over TLSããããŠãã®åŸæå·åãããIMAPãä»ããŠå®å ã®é»è©±ã¡ãã»ãŒãžã ãããŠããã¯è¯ãããšã§ãã
Yandex Mailãããã³ã«ã§ã®æå·åã®ãµããŒã
2009幎ã IMAPã®ç«ã¡äžããšåæã« ãPOP3ã€ã³ã¿ãŒãã§ã€ã¹ã«SSL / TLSãµããŒããè¿œå ããŸããã ã»ãŒåææã«ãSMTPã§æå·åãè¡ãããé»åã¡ãŒã«ããã°ã©ã ããé»åã¡ãŒã«ãåä¿¡ããŸããã çŸåšã4幎以äžçµã£ãŠãããµãŒããŒã§ã¯ã¡ãŒã«ããã°ã©ã ããå®å šã§ãªãæ¥ç¶ãéãããšãã§ããŸããã䜿çšããããšã¯ãå§ãããŸããããå¯èœã§ããã°ææžåããããšã¯ã§ããŸããã

Yandex.Mailã¢ãã€ã«ã¢ããªã±ãŒã·ã§ã³ã¯åžžã«SSL / TLSæ¥ç¶ã䜿çšããå éšã§ã¯XMPPãããã³ã«ã䜿çšããŸãã
2011幎ãWebã€ã³ã¿ãŒãã§ãŒã¹mail.yandex.ru㧠HTTPSãæå¹ã«ãããŠãŒã¶ãŒæ å ±ãã¯ã©ãŠãã«è»¢éãããã¹ãŠã®äž»èŠãªæ¹æ³ãã«ããŒããŸããã ä»å¹Žãç§ãã¡ã¯ã¡ãŒã«ã«ã¢ã¯ã»ã¹ãããšãã«HTTPSãå¿ é ã«ããä»é±ã¯å®å šã§ãªããããã³ã«ãä»ããŠæ¥ç¶ããæ©äŒãç¡å¹ã«ããŸããããŸããèªèšŒã·ã¹ãã ã§ããYandex.Passportã§ãŠãŒã¶ãŒãã¹ã¯ãŒããä¿è·ããçŽ æŽãããä»äºãããŸããã

ããã¯ãå€éšãšã®SMTPéä¿¡ãµãŒããŒäžã®æå·åããããã©ãã£ãã¯ãšéåžžã®ãã©ãã£ãã¯ã®æ¯çãçŸåšã©ã®ããã«èŠãããã§ãã


çµããã«è¿ã¥ããŠãã2013幎ã¯ãæ¿åºæ©é¢ã«ããããŒã¿ã®å€§éçèŽã«é¢é£ãã泚ç®ãéããã¹ãã£ã³ãã«ã®å¹Žãšãåºç¯å²ã«ãããã¯ã©ãŠãæå·åã®æåã®å¹Žã®äž¡æ¹ãšèªä¿¡ãæã£ãŠåŒã¶ããšãã§ããŸãã æ¥çã®ååå šå¡ã«ãã®ãã¬ã³ãã«åå ãããããã¯ãŒã¯äžã®ãã¹ãŠã®ãŠãŒã¶ãŒããŒã¿ã®å®å šãªæå·åã«åããŠè¬åº§ãåè¬ããããšããå§ãããŸãã ãã®ãããªããšã
PSïŒãšãã¯ãŒããããã«ã¡ã¯ïŒ :)
PPSïŒãšãã¯ãŒãã»ã¹ããŒãã³ã¯æ©èœãããYandexã§è·ãåŸãããšã¯ãããŸããã