Download free for 30 days
Sign in
Upload
Language (EN)
Support
Business
Mobile
Social Media
Marketing
Technology
Art & Photos
Career
Design
Education
Presentations & Public Speaking
Government & Nonprofit
Healthcare
Internet
Law
Leadership & Management
Automotive
Engineering
Software
Recruiting & HR
Retail
Sales
Services
Science
Small Business & Entrepreneurship
Food
Environment
Economy & Finance
Data & Analytics
Investor Relations
Sports
Spiritual
News & Politics
Travel
Self Improvement
Real Estate
Entertainment & Humor
Health & Medicine
Devices & Hardware
Lifestyle
Change Language
Language
English
Español
Português
Français
Deutsche
Cancel
Save
Submit search
EN
Uploaded by
Yoshio Hanawa
125,178 views
偶然にも500万個のSSH公開鍵を手に入れた俺たちは
2015/1/24 江戸前セキュリティ勉強会のLT発表資料です
Software
◦
Read more
217
Save
Share
Embed
Embed presentation
Download
Downloaded 130 times
1
/ 21
2
/ 21
3
/ 21
4
/ 21
5
/ 21
6
/ 21
7
/ 21
8
/ 21
9
/ 21
10
/ 21
11
/ 21
12
/ 21
13
/ 21
14
/ 21
15
/ 21
16
/ 21
17
/ 21
18
/ 21
19
/ 21
20
/ 21
21
/ 21
More Related Content
PDF
高速フーリエ変換
by
AtCoder Inc.
PDF
katagaitai CTF勉強会 #5 Crypto
by
trmr
PDF
暗号技術の実装と数学
by
MITSUNARI Shigeo
PDF
GitHubにバグ報告して賞金$500を頂いた話
by
Yoshio Hanawa
PPTX
BuildKitによる高速でセキュアなイメージビルド
by
Akihiro Suda
PDF
SQLアンチパターン - ジェイウォーク
by
ke-m kamekoopa
PDF
こわくない Git
by
Kota Saito
PPTX
OpenAI FineTuning を試してみる
by
iPride Co., Ltd.
高速フーリエ変換
by
AtCoder Inc.
katagaitai CTF勉強会 #5 Crypto
by
trmr
暗号技術の実装と数学
by
MITSUNARI Shigeo
GitHubにバグ報告して賞金$500を頂いた話
by
Yoshio Hanawa
BuildKitによる高速でセキュアなイメージビルド
by
Akihiro Suda
SQLアンチパターン - ジェイウォーク
by
ke-m kamekoopa
こわくない Git
by
Kota Saito
OpenAI FineTuning を試してみる
by
iPride Co., Ltd.
What's hot
PDF
AtCoder Beginner Contest 023 解説
by
AtCoder Inc.
PDF
ダブリング
by
satanic
PDF
プログラミングコンテストでのデータ構造
by
Takuya Akiba
PDF
新入社員のための大規模ゲーム開発入門 サーバサイド編
by
infinite_loop
PDF
20分くらいでわかった気分になれるC++20コルーチン
by
yohhoy
PPTX
冬のLock free祭り safe
by
Kumazaki Hiroki
PDF
Dockerfileを改善するためのBest Practice 2019年版
by
Masahito Zembutsu
PPTX
地理分散DBについて
by
Kumazaki Hiroki
PPTX
C# 8.0 非同期ストリーム
by
信之 岩永
PDF
Pythonの理解を試みる 〜バイトコードインタプリタを作成する〜
by
Preferred Networks
PDF
UEFIで始めるLinux From Scratch
by
Yuma Ohgami
PPTX
【DL輪読会】言語以外でのTransformerのまとめ (ViT, Perceiver, Frozen Pretrained Transformer etc)
by
Deep Learning JP
PPTX
純粋関数型アルゴリズム入門
by
Kimikazu Kato
PDF
Transformerを用いたAutoEncoderの設計と実験
by
myxymyxomatosis
PPTX
CyberChefの使い方(HamaCTF2019 WriteUp編)
by
Shota Shinogi
PDF
MariaDBとMroongaで作る全言語対応超高速全文検索システム
by
Kouhei Sutou
PDF
ソーシャルゲームのためのデータベース設計
by
Yoshinori Matsunobu
PDF
ネットワーク ゲームにおけるTCPとUDPの使い分け
by
モノビット エンジン
PPTX
paizaのオンラインジャッジを支えるDockerとその周辺
by
paiza
PDF
Raspberry PiのUSB OTGを試す
by
Kenichiro MATOHARA
AtCoder Beginner Contest 023 解説
by
AtCoder Inc.
ダブリング
by
satanic
プログラミングコンテストでのデータ構造
by
Takuya Akiba
新入社員のための大規模ゲーム開発入門 サーバサイド編
by
infinite_loop
20分くらいでわかった気分になれるC++20コルーチン
by
yohhoy
冬のLock free祭り safe
by
Kumazaki Hiroki
Dockerfileを改善するためのBest Practice 2019年版
by
Masahito Zembutsu
地理分散DBについて
by
Kumazaki Hiroki
C# 8.0 非同期ストリーム
by
信之 岩永
Pythonの理解を試みる 〜バイトコードインタプリタを作成する〜
by
Preferred Networks
UEFIで始めるLinux From Scratch
by
Yuma Ohgami
【DL輪読会】言語以外でのTransformerのまとめ (ViT, Perceiver, Frozen Pretrained Transformer etc)
by
Deep Learning JP
純粋関数型アルゴリズム入門
by
Kimikazu Kato
Transformerを用いたAutoEncoderの設計と実験
by
myxymyxomatosis
CyberChefの使い方(HamaCTF2019 WriteUp編)
by
Shota Shinogi
MariaDBとMroongaで作る全言語対応超高速全文検索システム
by
Kouhei Sutou
ソーシャルゲームのためのデータベース設計
by
Yoshinori Matsunobu
ネットワーク ゲームにおけるTCPとUDPの使い分け
by
モノビット エンジン
paizaのオンラインジャッジを支えるDockerとその周辺
by
paiza
Raspberry PiのUSB OTGを試す
by
Kenichiro MATOHARA
Viewers also liked
PDF
プログラムを高速化する話
by
京大 マイコンクラブ
PDF
インフラエンジニアの綺麗で優しい手順書の書き方
by
Shohei Koyama
PDF
実践イカパケット解析
by
Yuki Mizuno
PDF
オンラインゲームの仕組みと工夫
by
Yuta Imai
PDF
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
by
Takuto Wada
PPTX
技術選択とアーキテクトの役割
by
Toru Yamaguchi
PDF
運用に自動化を求めるのは間違っているだろうか
by
Masahito Zembutsu
PDF
SSL/TLSの基礎と最新動向
by
shigeki_ohtsu
PDF
「内積が見えると統計学も見える」第5回 プログラマのための数学勉強会 発表資料
by
Ken'ichi Matsui
PDF
プログラム組んだら負け!実はHTML/CSSだけでできること2015夏
by
Yusuke Hirao
PDF
フーリエ変換と画像圧縮の仕組み
by
yuichi takeda
PDF
MySQL 5.7の罠があなたを狙っている
by
yoku0825
PDF
MySQLテーブル設計入門
by
yoku0825
PPTX
Webアプリケーション負荷試験実践入門
by
樽八 仲川
PDF
「スプラトゥーン」リアルタイム画像解析ツール 「IkaLog」の裏側
by
Takeshi HASEGAWA
PDF
中の下のエンジニアを脱出するための仕事術
by
Noriaki Kadota
PDF
インフラエンジニアがUnityをやるべきたった一つの理由
by
axsh co., LTD.
PPTX
ちゃんとした C# プログラムを書けるようになる実践的な方法~ Visual Studio を使った 高品質・低コスト・保守性の高い開発
by
慎一 古賀
PDF
エンジニアのための経営学
by
Michitaka Yumoto
PDF
ウェブパフォーマンスの基礎とこれから
by
Hiroshi Kawada
プログラムを高速化する話
by
京大 マイコンクラブ
インフラエンジニアの綺麗で優しい手順書の書き方
by
Shohei Koyama
実践イカパケット解析
by
Yuki Mizuno
オンラインゲームの仕組みと工夫
by
Yuta Imai
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
by
Takuto Wada
技術選択とアーキテクトの役割
by
Toru Yamaguchi
運用に自動化を求めるのは間違っているだろうか
by
Masahito Zembutsu
SSL/TLSの基礎と最新動向
by
shigeki_ohtsu
「内積が見えると統計学も見える」第5回 プログラマのための数学勉強会 発表資料
by
Ken'ichi Matsui
プログラム組んだら負け!実はHTML/CSSだけでできること2015夏
by
Yusuke Hirao
フーリエ変換と画像圧縮の仕組み
by
yuichi takeda
MySQL 5.7の罠があなたを狙っている
by
yoku0825
MySQLテーブル設計入門
by
yoku0825
Webアプリケーション負荷試験実践入門
by
樽八 仲川
「スプラトゥーン」リアルタイム画像解析ツール 「IkaLog」の裏側
by
Takeshi HASEGAWA
中の下のエンジニアを脱出するための仕事術
by
Noriaki Kadota
インフラエンジニアがUnityをやるべきたった一つの理由
by
axsh co., LTD.
ちゃんとした C# プログラムを書けるようになる実践的な方法~ Visual Studio を使った 高品質・低コスト・保守性の高い開発
by
慎一 古賀
エンジニアのための経営学
by
Michitaka Yumoto
ウェブパフォーマンスの基礎とこれから
by
Hiroshi Kawada
More from Yoshio Hanawa
PDF
realpathキャッシュと OPcacheの面倒すぎる関係
by
Yoshio Hanawa
PDF
PHP7で変わること ——言語仕様とエンジンの改善ポイント
by
Yoshio Hanawa
PDF
OPcacheの新機能ファイルベースキャッシュの内部実装を読んでみた
by
Yoshio Hanawa
PPTX
自宅の消費電力をリアルタイムに グラフ化してみた
by
Yoshio Hanawa
PDF
Zend VMにおける例外の実装
by
Yoshio Hanawa
PDF
浮動小数点数とOSSのバグの話
by
Yoshio Hanawa
PDF
PHP拡張をPECLに登録してわかったこと
by
Yoshio Hanawa
PDF
PHP7の拡張モジュール事情
by
Yoshio Hanawa
PDF
PHPの拡張モジュールをGoで作る
by
Yoshio Hanawa
PDF
iOS/macOSとAndroid/Linuxのサンドボックス機構について調べた
by
Yoshio Hanawa
PDF
PHPの正規表現と最長一致
by
Yoshio Hanawa
PDF
php-buildがいかに便利かを力説する
by
Yoshio Hanawa
PDF
PHP7はなぜ速いのか
by
Yoshio Hanawa
PDF
PHP7の内部実装から学ぶ性能改善テクニック
by
Yoshio Hanawa
PDF
「OKグーグル! 銀行振込1000円」
by
Yoshio Hanawa
PDF
GitHubからお金をもらった話
by
Yoshio Hanawa
PDF
Laungage Update PHP編
by
Yoshio Hanawa
PDF
ぼくのかんがえる さいきょうの銀行振込
by
Yoshio Hanawa
PDF
家庭用ブロードバンドルータ上でWordPressを動かそう
by
Yoshio Hanawa
PDF
Zend VMにおける例外の実装
by
Yoshio Hanawa
realpathキャッシュと OPcacheの面倒すぎる関係
by
Yoshio Hanawa
PHP7で変わること ——言語仕様とエンジンの改善ポイント
by
Yoshio Hanawa
OPcacheの新機能ファイルベースキャッシュの内部実装を読んでみた
by
Yoshio Hanawa
自宅の消費電力をリアルタイムに グラフ化してみた
by
Yoshio Hanawa
Zend VMにおける例外の実装
by
Yoshio Hanawa
浮動小数点数とOSSのバグの話
by
Yoshio Hanawa
PHP拡張をPECLに登録してわかったこと
by
Yoshio Hanawa
PHP7の拡張モジュール事情
by
Yoshio Hanawa
PHPの拡張モジュールをGoで作る
by
Yoshio Hanawa
iOS/macOSとAndroid/Linuxのサンドボックス機構について調べた
by
Yoshio Hanawa
PHPの正規表現と最長一致
by
Yoshio Hanawa
php-buildがいかに便利かを力説する
by
Yoshio Hanawa
PHP7はなぜ速いのか
by
Yoshio Hanawa
PHP7の内部実装から学ぶ性能改善テクニック
by
Yoshio Hanawa
「OKグーグル! 銀行振込1000円」
by
Yoshio Hanawa
GitHubからお金をもらった話
by
Yoshio Hanawa
Laungage Update PHP編
by
Yoshio Hanawa
ぼくのかんがえる さいきょうの銀行振込
by
Yoshio Hanawa
家庭用ブロードバンドルータ上でWordPressを動かそう
by
Yoshio Hanawa
Zend VMにおける例外の実装
by
Yoshio Hanawa
偶然にも500万個のSSH公開鍵を手に入れた俺たちは
1.
Attacking against 5
million SSH public keys 偶然にも500万個の SSH公開鍵を 手に入れた俺たちは hnw 江戸前セキュリティ勉強会 (2015/1/24)発表資料
2.
自己紹介 ❖ @hnw ❖ カレーとバグが大好物 ❖
PHPの方から来ました
3.
アジェンダ ❖ SSH公開鍵の集め方 ❖ 弱い鍵を見つけた ❖
公約数を探す
4.
❖ SSH公開鍵の集め方 ❖ 弱い鍵を見つけた ❖
公約数を探す
5.
SSH公開鍵を集める ❖ github.comで集めました ❖ GitHub
APIでユーザーIDが全件取れる ❖ https://github.com/[ユーザーID].keys ❖ 登録しているSSH公開鍵が誰でも取得できる ❖ obsoleteらしいが、長いこと使えている
6.
SSH公開鍵を集める ❖ github.com全850万ユーザー(昨年10月当時) ❖ 鍵の取得だけで2日くらいかかった ❖
約500万個のSSH公開鍵が手に入った
7.
❖ SSH公開鍵の集め方 ❖ 弱い鍵を見つけた ❖
公約数を探す
8.
弱い鍵ペア ❖ 理屈上、公開鍵暗号では秘密鍵がバレなければ安全 ❖ 公開鍵が500万件もあるとヘマする人もいる ❖
秘密鍵を特定できる公開鍵が実際に見つかった
9.
鍵長が短すぎる鍵 ❖ 攻撃可能そうな鍵が35個みつかった ❖ 256bit
DSA鍵 1個 ❖ 512bit DSA鍵 11個 ❖ 256bit RSA鍵 11個 ❖ 512bit RSA鍵 12個 ❖ 鍵長を明示的に指定して鍵ペア生成しているはず ❖ 公開鍵暗号についての理解が足りない?
10.
鍵長が短すぎる鍵 ❖ 短いRSA鍵は素因数分解で破れる ❖ 256bit
RSA鍵の場合 ❖ p,qともに128bit(10進39桁)の素数 ❖ n(=pq)だけをもとにnを素因数分解すればよい ❖ 素因数分解の実装はネット上に落ちている ❖ 256bit RSA鍵なら3秒で素因数分解できた
11.
古いDebianで作られた脆弱な鍵 ❖ CVE-2008-0166 ❖ Debian系distroのOpenSSL実装にバグが混入した ❖
作られるSSH鍵ペアが32767パターンになる ❖ 全パターンのSSHユーザー鍵を公開している人がいる ❖ 208件が一致した
12.
❖ SSH公開鍵の集め方 ❖ 弱い鍵を見つけた ❖
公約数を探す
13.
RSAに対する既知の攻撃 ❖ 論文「Mining Your
Ps and Qs: Detection of Widespread Weak Keys in Network Devices」 ❖ 乱数生成器の偏りを利用したRSAに対する攻撃 ❖ 多数の公開鍵から公約数を見つけるもの ❖ SSL証明書とSSHホスト鍵あわせて1100万個を調査 ❖ 約6万個の鍵を素因数分解できた
14.
ここに公開鍵がたくさんあるじゃろ? ❖ 論文の筆者が作ったプログラムは公開されている ❖ fastgcd ❖
https://factorable.net/resources.html
15.
SSHユーザー鍵でGCD計算 ❖ メモリとストレージが必要 ❖ いったん全部の積を求めるため ❖
500万個のGCD計算がAWSなら100円 ❖ c3.4xlarge(メモリ30GB)で40分
16.
SSHユーザー鍵でGCD計算 ❖ 期待通りに素因数分解できたものは無かった ❖ 乱数生成器の偏りは見つからなかった
17.
SSHユーザー鍵でGCD計算 ❖ 155個について約数が見つかった ❖ 16進1桁から7桁の数で割り切れる ❖
割ってもまだ合成数 ❖ コピペミスした公開鍵が登録されている?
18.
コピペミスした鍵のリスク ❖ 正しい秘密鍵でもログインできない状態 ❖ nの素因数分解さえできれば秘密鍵は作れる ❖
nの素因数が偶然小さい素数ばかりだと危険 ❖ あまり指摘されていないリスクなのでは?
19.
まとめ ❖ 多数のSSH公開鍵を調査した ❖ リスクのある鍵を使っているユーザーが実在する ❖
攻撃者有利な時代だと再認識した ❖ 実装、データ、計算機いずれも簡単に手に入る
20.
懇親会にも参加します ❖ アドバイス・雑談などお待ちしております
21.
ご静聴 ありがとう ございました
Download