ã¹ãã¬ãŒãžã·ã¹ãã ãã
ããã¯ã¢ãããŸã§ãããŸããŸãªãã¯ãããžãŒã«ã€ããŠãã話ã
ãŸã ã ããã«ãç§ãã¡ã¯IaaSãããã€ããŒã®ä»äºãæé©åããçµéšãå
±æããŠ
ããŸã ã
ãµãŒãã¹ã®äœ¿ãããããæ¹åããããã®ç®¡çã®åŽé¢ãšæ©äŒã«ã€ããŠè©±ããŠ
ããã®ã§ãã
ä»æ¥ãç§ãã¡ã¯ã»ãã¥ãªãã£ã®ãããã¯ã«è§ŠããSSLã«ã€ããŠè©±ãããšã«ããŸããã
蚌ææžãä¿¡é Œã§ããæ¥ç¶ãæäŸããããšã¯èª°ããç¥ã£ãŠã
ãŸãããããã©ã®ããã«çºçããããç解ãã䜿çšãããŠãããããã³ã«ãèŠãŠã¿ãŸãããã
/ Flickr / ããããã²ãŒãªã³ã° / cc-bySSLïŒã»ãã¥ã¢ãœã±ããã¬ã€ã€ãŒïŒã¯ãã»ãã¥ã¢ãªéä¿¡ã®ããã®æå·åãããã³ã«ã§ãã ããŒãžã§ã³3.0以éãSSLã¯TLSïŒãã©ã³ã¹ããŒãã¬ã€ã€ãŒã»ãã¥ãªãã£-ãã©ã³ã¹ããŒãã¬ã€ã€ãŒã»ãã¥ãªãã£ïŒã«çœ®ãæããããŸãããã以åã®ããŒãžã§ã³ã®ååãæ ¹ä»ãããããä»æ¥ã®TLSã¯ã»ãšãã©ã®å ŽåSSLãšããŠç解ãããŠããŸãã
ãã®ãããã³ã«ã®ç®çã¯ãå®å
šãªããŒã¿äŒéãæäŸããããšã§ãã åæã«ãèªèšŒã«ã¯é察称æå·åã¢ã«ãŽãªãºã ïŒå
¬ééµãšç§å¯éµã®ãã¢ïŒã䜿çšãããæ©å¯æ§ãç¶æããããã«å¯Ÿç§°ïŒç§å¯éµïŒã䜿çšãããŸãã æåã®ã¿ã€ãã®æå·åã¯ãããªãœãŒã¹ãæ¶è²»ããããã察称ã¢ã«ãŽãªãºã ãšçµã¿åãããããšã§ãé«ãããŒã¿åŠçé床ãç¶æã§ããŸãã
æ¡æ
ãŠãŒã¶ãŒãWebãµã€ãã«ã¢ã¯ã»ã¹ãããšããã©ãŠã¶ãŒã¯ãµãŒããŒã«èšŒææžæ
å ±ãèŠæ±ãããµãŒããŒã¯SSL蚌ææžã®ã³ããŒãå
¬éããŒãšãšãã«éä¿¡ããŸãã 次ã«ããã©ãŠã¶ã¯èšŒææžã確èªããŸãã蚌ææžã®ååã¯Webãµã€ãã®ååãšäžèŽããå¿
èŠããããŸãã
ãŸãã蚌ææžã®æå¹æéãšãä¿¡é Œã§ãã蚌ææ©é¢ã«ãã£ãŠçºè¡ãããã«ãŒã蚌ææžã®å¯çšæ§ã確èªãããŸãã ãã©ãŠã¶ã蚌ææžãä¿¡é ŒããŠããå Žåããã©ãŠã¶ã¯ãå
¬ééµã«åºã¥ããŠã»ãã·ã§ã³ã®äºåã·ãŒã¯ã¬ããïŒããªãã¹ã¿ãŒã·ãŒã¯ã¬ããïŒãçæããŸããããã«ã¯ãå¯èœãªéãæé«ã¬ãã«ã®æå·åã䜿çšãããŸãã

ãµãŒããŒã¯ãç§å¯éµã䜿çšããŠäºåã·ãŒã¯ã¬ããã埩å·åããéä¿¡ãç¶è¡ããç¹å®ã®ã¿ã€ãã®æå·åã䜿çšããŠå
±æã·ãŒã¯ã¬ããïŒãã¹ã¿ãŒã·ãŒã¯ã¬ããïŒãäœæããããšã«åæããŸãã çŸåšãäž¡åŽã§å¯Ÿç§°ããŒã䜿çšãããŠããŸãããããã¯ãã®ã»ãã·ã§ã³ã§ã®ã¿æå¹ã§ãã å®äºåŸãããŒã¯ç Žæ£ããã次ã«ãµã€ãã«ã¢ã¯ã»ã¹ãããšãã«ãæåã«ãã³ãã·ã§ã€ã¯ããã»ã¹ãéå§ãããŸãã
æå·åã¢ã«ãŽãªãºã
察称æå·åã§ã¯ãç°ãªãã¢ã«ãŽãªãºã ã䜿çšãããŸããã 1ã€ç®ã¯ãIBMãéçºãããããã¯DES
æå·ã§ãã ç±³åœã§ã¯ã70幎代ã«æšæºãšããŠæ¿èªãããŸããã ãã®ã¢ã«ãŽãªãºã ã¯ã16ãµã€ã¯ã«ã®
Feistelãããã¯ãŒã¯ã«åºã¥ããŠ
ããŸã ã ããŒã®é·ãã¯56ãããã§ãããŒã¿ãããã¯ã¯64ã§ãã
DESã®éçºã¯3DESã¢ã«ãŽãªãºã ã§ãã ãã
㯠ãåé§ã¢ã«ãŽãªãºã ã®çãããŒãæ¹åããç®çã§
äœæãããŸããã ããŒãµã€ãºãšæå·åãµã€ã¯ã«ã®æ°ã3åã«å¢å ãããããäœæ¥é床ã¯äœäžããŸããããä¿¡é Œæ§ã¯åäžããŸããã
ãŸããDESãããé«éã«æ©èœããå¯å€ããŒé·ã®ãããã¯
æå· RC2ãããããã®128ãããããŒã®ä¿¡é Œæ§ã¯3DESãšåçã§ããã RC4ã¹ããªãŒã
æå·ã¯ããããã¯
æå·ãããã¯ããã«é«éã§ãããæ¬äŒŒã©ã³ãã ããããžã§ãã¬ãŒã¿ãŒã«åºã¥ããŠããŸããã ããããä»æ¥ããããã®ã¢ã«ãŽãªãºã
ã¯ãã¹ãŠå®å
šã§ã¯ãªãããæ代é
ã
ãšã¿ãªãããŠããŸãã
æãè¿ä»£çãªã®ã¯
ã 2002幎ã«DESãæ£åŒã«çœ®ãæã
ã AES
æšæºã§ãã Rijndaelãããã¯ã¢ã«ãŽãªãºã ã«åºã¥ããŠããããã®é床ã¯3DESã«æ¯ã¹ãŠ6åé«éã§ãã ããã§ã®ãããã¯ãµã€ãºã¯128ãããã§ãããŒãµã€ãºã¯128/192/256ãããã§ããæå·åã©ãŠã³ãã®åæ°ã¯ããŒãµã€ãºã«ãã£ãŠç°ãªãããããã10/12/14ã«ãªããŸãã
é察称æå·åã«é¢ããŠã¯ãã»ãšãã©ã®å ŽåãRSAãDSAãECCãªã©ã®ã¢ã«ãŽãªãºã ã«åºã¥ããŠæ§ç¯ãããŸãã RSAïŒRivestãShamirãããã³Adlemanã®èè
ã«ã¡ãªãã§åä»ããããïŒã¯ãæå·åãšããžã¿ã«çœ²åã®äž¡æ¹ã«äœ¿çšãããŸãã ãã®ã¢ã«ãŽãªãºã ã¯ãå€æ°ã®å æ°å解ã®è€éãã«åºã¥ããŠããããã¹ãŠã®ã¿ã€ãã®SSL蚌ææžããµããŒãããŠããŸãã
DSAïŒããžã¿ã«çœ²åã¢ã«ãŽãªãºã ïŒã¯ãããžã¿ã«çœ²åãäœæããããã«ã®ã¿äœ¿çšãããæéãã£ãŒã«ãã§å¯Ÿæ°ãåãèšç®ã®è€éãã«åºã¥ããŠããŸãã å®å
šæ§ãšçç£æ§ã«ã€ããŠã¯ãRSAã«å®å
šã«å¹æµããŸãã
ECCïŒæ¥åæ²ç·æå·åïŒã¯ãæ²ç·äžã®ãããã䜿çšããŠããŒãã¢ãå®çŸ©ããããžã¿ã«çœ²åã«ã®ã¿äœ¿çšãããŸãã ãã®ã¢ã«ãŽãªãºã ã®äž»ãªå©ç¹ã¯ãããŒã®é·ããçãä¿¡é Œæ§ãé«ãããšã§ãïŒ256ãããECCããŒã¯ã3072ãããRSAããŒãš
åçã®ä¿¡é Œæ§ã§ãã
çãããŒã¯ããŒã¿åŠçæéã«ã圱é¿ããããã¯èããççž®ãããŸãã ãã®äºå®ãšãã¢ã«ãŽãªãºã ãå€æ°ã®æ¥ç¶ãå¹ççã«åŠçãããšããäºå®ã«ãããã¢ãã€ã«éä¿¡ã§äœæ¥ããããã®äŸ¿å©ãªããŒã«ãšãªããŸããã SSL蚌ææžã§ã¯ãã»ãã¥ãªãã£ã匷åããããã«ããã€ãã®æå·åæ¹æ³ã䜿çšã§ããŸãã
ããã·ã¥ãšMAC
ããã·ã¥ã¢ã«ãŽãªãºã ã®ç®çã¯ãSSL蚌ææžã®å
容å
šäœãåºå®é·ã®ãããæååã«
å€æããããšã§ãã ããã·ã¥å€ãæå·åããããã«ã蚌ææ©é¢ã®ç§å¯ããŒã䜿çšãããŸããããã¯ã蚌ææžãšããŠçœ²åãšããŠå«ãŸããŠããŸãã
ããã·ã¥ã¢ã«ãŽãªãºã ã¯ãéä¿¡ãããããŒã¿ã®æŽåæ§ãæ€èšŒããããã«å¿
èŠãªå€-MACïŒã¡ãã»ãŒãžèªèšŒã³ãŒãïŒã
䜿çšããŸãã MACã¯ããããã³ã°é¢æ°ã䜿çšããŠãã¡ãã»ãŒãžããŒã¿ãåºå®é·å€ãšããŠè¡šããã¡ãã»ãŒãžãããã·ã¥ããŸãã
TLSãããã³ã«ã¯HMACïŒããã·ã¥ã¡ãã»ãŒãžèªèšŒã³ãŒãïŒã䜿çšããŸããããã¯ãå
±æç§å¯ããŒã䜿çšããŠããã«ããã·ã¥ã¢ã«ãŽãªãºã ã䜿çšããŸãã ããã§ã¯ãããŒãããŒã¿ã«æ·»ä»ãããŠãããä¿¡é Œæ§ã確èªããããã«ãäž¡è
ã¯åãç§å¯ããŒã䜿çšããå¿
èŠããããããã«ããã»ãã¥ãªãã£ã匷åãããŸãã
çŸåšããã¹ãŠã®æå·åã¢ã«ãŽãªãºã ã¯SHA2ããã·ã¥ã¢ã«ãŽãªãºã ããµããŒãããŠããŸããã»ãšãã©ã®å ŽåãSHA-256ã§ãã SHA-512ã
åæ§ã®æ§é ãæã£ãŠã
ãŸãããã¯ãŒãé·ã¯64ãããïŒ32ã§ã¯ãªãïŒããµã€ã¯ã«ã®ã©ãŠã³ãæ°ã¯80ïŒ64ã§ã¯ãªãïŒãã¡ãã»ãŒãžã¯1024ãããïŒ512ãããã§ã¯ãªãïŒã®ãããã¯ã«åå²ãããŸãã 以åã¯ãSHA1ããã³MD5ã¢ã«ãŽãªãºã ã¯åãç®çã§äœ¿çšãããŠããŸããããçŸåšã¯
è匱ã§ãããšèŠãªãããŠã
ãŸã ã
SHA1ã®æŸæ£ã«ã€ããŠã®è©±ã¯é·ãéè¡ãããŠããŸãããã2ææ«ã«ã¢ã«ãŽãªãºã ã¯å
¬åŒã«
ãããã³ã°ãããŸãã ã ç 究è
ã¯ããã·ã¥ã®è¡çªãã€ãŸã2ã€ã®ç°ãªããã¡ã€ã«ã®åãããã·ã¥ãéæããããšãã§ããŸãããããã«ãããããžã¿ã«çœ²åã«ã¢ã«ãŽãªãºã ã䜿çšããããšã®å®å
šæ§ã蚌æãããŸããã æåã®è©Šã¿ã¯2015幎ã«è¡ãããŸãããããã®æç¹ã§ã¯ããã·ã¥ãäžèŽããã¡ãã»ãŒãžã®ã¿ãããã¯ã¢ããã§ããŸããã ä»æ¥ã¯ããã¥ã¡ã³ãå
šäœã«ã€ããŠè©±ããŸãã
蚌ææžã¯ç°ãªããŸã
SSL / TLSãšã¯äœããããã«åºã¥ããæ¥ç¶ã®ç¢ºç«æ¹æ³ãããã£ãã®ã§
ã蚌ææžã®
çš®é¡ã«ã€ããŠã話ããŸãã
ãã¡ã€ã³æ€èšŒããŸãã¯ãã¡ã€ã³æ€èšŒããã蚌ææžã¯ã移è¡ãè¡ãããç¹å®ã®ãµã€ãã«ãµãŒãã¹ãæäŸããWebãµãŒããŒã®ã¿ã確èªãããããéå¶å©ãµã€ãã«é©ããŠããŸãã ãã®ã¿ã€ãã®èšŒææžã¯æãå®äŸ¡ã§äººæ°ããããŸãããç»é²ããããã¡ã€ã³åã«é¢ããæ
å ±ã®ã¿ãå«ãŸããŠãããããå®å
šã«å®å
šã§ãããšã¯èŠãªããŸããã
çµç¹ã®æ€èšŒããŸãã¯çµç¹ã®æ€èšŒã䌎ã蚌ææžã¯ãææäŒç€Ÿã®ç»é²ããŒã¿ã確èªãããããããä¿¡é Œæ§ãé«ããªããŸãã æ³äººã¯èšŒææžã賌å
¥ããéã«ãã®æ
å ±ãæäŸããå¿
èŠããããèªèšŒã»ã³ã¿ãŒã¯äŒç€Ÿã«çŽæ¥é£çµ¡ããŠãã®æ
å ±ã確èªã§ããŸãã 蚌ææžã¯
RFCèŠæ Œã«é©åããŠããã蚌ææžã®ç¢ºèªè
ã«é¢ããæ
å ±ãå«ãŸããŠããŸãããææè
ã«é¢ããæ
å ±ã¯è¡šç€ºãããŸããã
æ¡åŒµæ€èšŒããŸãã¯æ¡åŒµæ€èšŒèšŒææžã¯ãæãä¿¡é Œã§ãããšèŠãªãããŸãã å®éããã©ãŠã¶ã®ç·è²ã®ããã¯ãŸãã¯ã·ã§ãŒãã«ããã¯ããµã€ãã«ãã®ãããªèšŒææžãããããšãæå³ããŸãã
ããã§ãããŸããŸãªãã©ãŠã¶ã蚌ææžã®å¯çšæ§ãŸãã¯ãšã©ãŒã«ã€ããŠãŠãŒã¶ãŒã«éç¥ããæ¹æ³ã«ã€ããŠèªãããšãã§ã
ãŸã ã
éèååŒãè¡ããé«åºŠãªæ©å¯æ§ãå¿
èŠãšããWebãµã€ãã§å¿
èŠã§ãã ãã ããå€ãã®ãµã€ãã¯ãä»ã®ãŠãŒã¶ãŒããŒã¿ãä¿è·ããã®ã«ååãªOV蚌ææžã䜿çšããªããããŠãŒã¶ãŒããªãã€ã¬ã¯ãããŠãé«åºŠãªæ€èšŒãåãã蚌ææžã«ãã£ãŠç¢ºèªãããå€éšãªãœãŒã¹ãžã®æ¯æãã奜ã¿ãŸãã
ãŸãã蚌ææžã¯ãçºè¡ããããã¡ã€ã³ã®æ°ã«ãã£ãŠç°ãªãå ŽåããããŸãã åäžãã¡ã€ã³èšŒææžïŒåäžèšŒææžïŒã¯1ã€ã®ãã¡ã€ã³ã«é¢é£ä»ããããŠããã賌å
¥æã«ç€ºãããŸãã
ãã«ããã¡ã€ã³èšŒææžïŒãµããžã§ã¯ãã®å¥åããŠããã¡ã€ãã³ãã¥ãã±ãŒã·ã§ã³èšŒææžããã«ããã¡ã€ã³èšŒææžãªã©ïŒã¯ã泚ææã«æ±ºå®ãããå€æ°ã®ãã¡ã€ã³åãšãµãŒããŒã«å¯ŸããŠæå¹ã§ãã ãã ããç¹å®ã®åºæºãè¶
ããè¿œå ã®ãã¡ã€ã³ãå«ããå Žåã¯ãåå¥ã«æ¯æãå¿
èŠããããŸãã
ç»é²æã«æå®ããããã¡ã€ã³åã®ãã¹ãŠã®ãµããã¡ã€ã³ãã«ããŒãããµã
ãã¡ã€ã³èšŒææžïŒWildCardãªã©ïŒããŸã ãããŸãã 蚌ææžãå¿
èŠã«ãªãããšããããŸããããã«ã¯ãè€æ°ã®ãã¡ã€ã³ã ãã§ãªãããµããã¡ã€ã³ãåæã«å«ãŸããŸãã ãã®ãããªå Žåã
Comodo PositiveSSL Multi-Domain Wildcardã
Comodo Multi-Domain Wildcard SSLãŸãã¯ïŒã©ã€ãããã¯ïŒéåžžã®ãã«ããã¡ã€ã³èšŒææžãªã©ã®èšŒææžã賌å
¥ã§ããŸããããã§ã¯ããã¡ã€ã³ã®ãªã¹ãã§å¿
èŠãªãµããã¡ã€ã³åãæå®ããããšãã§ããŸãã
SSL蚌ææžã¯èªåã§ååŸã§ããŸãããã®ããã®ããŒãã¢ã¯ããžã§ãã¬ãŒã¿ãŒïŒç¡æã®
OpenSSLãªã©ïŒãä»ããŠçæãã
ãŸã ã ãŸãããããã¯ãŒã¯ãã¢ããªã±ãŒã·ã§ã³äžã®ããã€ã¹éãªã©ãå
éšç®çã§ãã®ãããªå®å
šãªéä¿¡ãã£ãã«ã䜿çšããããšã¯éåžžã«å¯èœã§ãã ãã ããWebãµã€ãã§èšŒææžã䜿çšããã«ã¯ã蚌ææžãæ£åŒã«è³Œå
¥ããå¿
èŠããããŸãããã®ããã蚌ææžç¢ºèªãã§ãŒã³ã«ã«ãŒã蚌ææžãããããã©ãŠã¶ãŒã¯å®å
šã§ãªãæ¥ç¶ã«é¢ããã¡ãã»ãŒãžã衚瀺ããããŠãŒã¶ãŒã¯èªåã®ããŒã¿ã«ã€ããŠèœã¡çããŠããŸãã
PSããã«ãIaaSãããã€ããŒ1ã¯ã©ãŠãã®ããã°ã®ãããã¯ã«ã€ããŠïŒ