SSHとは何か | 仕組みなどを初学者向けに解説

情報セキュリティ

SSHとは

Secure Shellの略です。一般的にShellはコンピュータに命令をするプログラムのことを指しますがSSH自体はクライアントとサーバー間の通信を安全に行う為の仕組みです。SSHを使うと通信の途中のデータはすべて暗号化されるので攻撃者がそのデータを傍受したとしても、攻撃者はそのデータが何なのかがわかりません。

SSHの仕組み

クライアントは公開鍵と秘密鍵を作る

クライアントは公開鍵と秘密鍵を生成します。生成した後、クライアントは公開鍵をサーバーに送信します。

乱数を生成し暗号化

公開鍵を送信した後、クライアントはログインID、パスワードを含むログインリクエストを送信します。サーバーはログインしていきたユーザとIPアドレスを記憶します。そしてサーバーは独自に乱数を生成します。この乱数をクライアントからもらった公開鍵を使って暗号化して、その暗号文をクライアントに送信します。またそれだけではなく乱数をハッシュ関数を使ってハッシュ値化して保存します。

ハッシュ値を比較して認証する

サーバーから送られてきた暗号文をクライアントは公開鍵で復号化します。当たり前ですがクライアント側で発行した公開鍵で暗号化されたデータは、クライアントが持つ秘密鍵のみ復号可能です。復号化したのち、クライアントはそのデータをサーバーに送信します。サーバーはそのデータを受け取った後、先ほど保存したハッシュ値と比較します。この値が一致するかどうかで認証を行います。ちなみにクライアントが秘密鍵で復号したデータはサーバーが乱数から生成したハッシュ値はクライアントが生成した公開鍵で暗号化し、その秘密鍵で復号した場合は値が一致するように作られています。

番外:その他おすすめの記事

開発がもっと快適に、楽しくなるアイテムを紹介します。アイテム1つで開発の楽しさが全然変わるので、良いアイテムにはじゃんじゃんお金を投資すると良いですよ。

おすすめアイテム①

自分はオフィス次の2点の座布団と背もたれクッションを利用してます。姿勢が安定し、お尻への負担が激減します。オフィスにいるのに自宅で作業しているような感覚になるので気に入ってます。また疲労感もかなり減るので費用対効果が非常に高いアイテムです。

おすすめアイテム②

ブックスタンドみなさん使ってますか?PCを打ちながら参考書見る時に手で抑える必要がなくなるので非常に便利です。自分も購入した時なんでいままで使ってなかたんだろうと後悔したのでまだ持ってない方は買っておくと作業効率があがります。

おすすめアイテム③

PCスタンド、magic keyboard、magic mouseを購入してから、開発効率があがり、身体的負担が減って快適に開発ができるようになりました。

エンジニアの基礎知識・教養

別の記事でエンジニアとして知っておくべき技術本についてまとめました。初心者には最低限読んでおいて欲しい技術本をまとめました。例えば「リーダブルコード」などは技術力の高いエンジニアなら必ず過去に読んでいる本だと思います。

時短アイテム!日々の生活の質を上げる

日常生活における無駄を省く表品をまとめました。1日無駄な作業時間が10分発生するとしたら1年間で3600時間もその無駄な作業に時間を費やすことになります。このような魔の作業を消し去ってくれる商品をまとめました。。

気軽にお声かけください

このような形でほぼ毎日、情報発信を行ってます。技術的な部分で誤っている点などもあるかもしれません。その様な部分を発見した方はTwitterのDMなどで知らせていただければ凄い嬉しいです。また自身自身のエンジニアのネットワークを広げたいと思ってます。日頃六本木や渋谷にいることが多いですので気軽にお誘いください。情報交換しましょう。

筆者
筆者

今回の記事の内容は以上で終了です。最後まで読んでくれてありがとうございました。Twitterもやってるのでフォローしてくれたら嬉しいです!

タイトルとURLをコピーしました