MEMORVA

安全なパスワードの作り方、総当たり攻撃、文字の種類と文字数(桁数)

更新:2024-09-17

SNSやウェブサービスからIDやパスワードなど個人情報が流出したニュースをたまに耳にする。 2024年にはニコニコ動画がサービスを長期間停止するほど大きな被害があった。 どんなに強固なパスワードを考えても、どこからかパスワードが漏れてしまうと意味がなく、パスワードの使い回しが一番危険なのかもしれない。

ただ、何か新規にパスワードを作らなければいけないとき、一応まじめに考える。 昔私は基本的に8桁で作っていたが、その後10桁、12桁など桁数を増やしている。 コンピュータの進化とともに、時代に合わせてパスワードを見直している。

安全とされるパスワードは、基本的に総当たり攻撃(ブルートフォースアタック)を想定していて、それに強いパスワードを指している。 総当たり攻撃というのは、例えば数字4桁のパスワードの場合、0000、0001、0002、・・・、9997、9998、9999と全ての組み合わせを試せばいずれ当たるというもの。 つまりパスワードは、桁数が多く、文字の種類が豊富なほど良いということになる。 数字は0~9の10種類しかないが、英字はa~zまで26種類あり、さらに大文字のA~Zもある。 またパスワードには !"#$%&'()=-^~\|@`[{;+:*]},<.>/?_ などの記号も使える場合がある。 パスワードはこれら全て混ぜて作るのが理想的とされる。

いろいろな種類の文字や記号を混ぜると覚えにくいので良くないという意見もあるが、覚えられるならその方が良い。 それに文字列の区切りとして大文字や記号を入れた方が覚えやすい場合もある。

  • 数字(0~9)
  • 英字小文字(a~z)
  • 英字大文字(A~Z)
  • 記号(!"#$%&'()=-^~\|@`[{;+:*]},<.>/?_)(使用可能な場合)

いくつかのサイトで試したが、Google、Yahoo! Japan、Amazon、X(旧Twitter)、Facebook といった大きいサイトはパスワードに記号も使えるが、一部の通販サイトなど、記号が使えないサイトも結構ある。

下表は、使用する文字の種類と各桁数における総当たりに必要な試行回数を記した。 例えば数字(0~9)の4桁は、0000から9999まで1万通りの組み合わせしかない。 サイトでパスワードを決める際、安全性の目安が表示されるサイトがあるが、概ね数字、英字(大小)、記号(使用可能な場合)を組み合わせて10桁程度で「安全」と表示される。 例えば、英字(大小あり)+数字+記号31文字の10桁のパスワードを総当りする場合、48,398,230,717,929,300,000(約4839京)ものパターンが存在する。

昨今、8桁未満はあまり現実的ではないので表から削除した。 代わりに12桁を追加した。

使用する文字の種類 使用可能文字数 8桁 10桁 12桁
数字(0~9) 10 100,000,000 10,000,000,000 1,000,000,000,000
英字(小文字a~zのみ) 26 208,827,064,576 141,167,095,653,376 141,167,095,653,376
英字(小文字a~zのみ)+数字 36 2,821,109,907,456 3,656,158,440,062,980 4,738,381,338,321,620,000
英字(大小あり)+数字 62 218,340,105,584,896 839,299,365,868,340,000 3,226,266,762,397,900,000,000
英字(大小あり)+数字+記号31文字 93 5,595,818,096,650,400 48,398,230,717,929,300,000 418,596,297,479,371,000,000,000

現実は

総当り攻撃はコンピュータの性能が良いほど速く試行でき、コンピュータの進化により総当りに要する時間は短縮されつつある。 総当り攻撃にどのくらい時間がかかるか実験している人もいる。 ただ、ウェブサーバーに対して何億何兆という総当り攻撃を行った場合、きちんと管理されているウェブサーバーであればそれに気づいて対処するだろう。 サイトによっては一定の試行回数を超えたらログインできなくなるものもある。 または自動的に検出しているサイトもある。

総当りの試行回数が少なすぎるパスワードや推測されやすいパスワードでない限り、無駄に長い試行回数が多いパスワードを作るのはあまり意味がないのかもしれない。 強固なパスワードを設定したにも関わらずアカウントが乗っ取られた場合、きちんと管理されていないウェブサーバーであったり、ローカルのパソコンなどからパスワードが漏れた可能性もある。 パスワードの使いまわしを避けたり、信頼性の低いソフトウェアのインストールを避けることが大切。