随想ノオト
テクノロジー · 読了 11分 · 2

WebアプリでHTTPが使われる場面:HTTPSとの使い分けと判断基準

TOC 結論: 本番でユーザーデータを扱う限りHTTPSが原則。HTTPは開発環境と信頼済みの閉域網に限る。 HTTPSがほぼ無料で使える時代に、「HTTPで十分な場面がまだ存在する」と言うと、驚かれることがあります。 実際には全部をHTTPSにすれば安全というほど単純ではなく、アーキテクチャの構造上HTTPが現れる箇…

by 編集部

結論: 本番でユーザーデータを扱う限りHTTPSが原則。HTTPは開発環境と信頼済みの閉域網に限る。

HTTPSがほぼ無料で使える時代に、「HTTPで十分な場面がまだ存在する」と言うと、驚かれることがあります。 実際には全部をHTTPSにすれば安全というほど単純ではなく、アーキテクチャの構造上HTTPが現れる箇所があります。 ただし「存在する」ことと「使っていい」かどうかは別の話です。この記事では両者をはっきり区別します。


HTTPSが「標準」になった経緯

2014年、GoogleはHTTPS化をランキングシグナルに組み込むと発表しました(Google Webmaster Central Blog)。 翌2015年にはLet’s Encryptが無料の自動証明書を提供し始め、コスト面での障壁がほぼ消えました。 2020年代に入ると、ChromeやFirefoxはHTTPサイトに「保護されていない通信」の警告を表示するようになり、今やHTTPS化は選択肢ではなく前提です。

そうした流れにもかかわらず、現場では依然としてHTTPが顔を出す場面があります。背景を理解しないまま「とりあえずHTTPS」と唱えるより、なぜHTTPSが必要なのかを知ったうえで例外を正しく評価するほうが実務の判断精度が上がります。


HTTPとHTTPSの違いを整理する

まず土台を確認します。

項目 HTTP HTTPS
レイヤー TCP/IP上の平文テキスト TLS(Transport Layer Security)で暗号化
ポート(慣例) 80 443
盗聴リスク 高(経路上で読める) 低(暗号化)
改ざんリスク 低(MACで検出)
証明書コスト 不要 Let’s Encryptで無料化済み
パフォーマンス わずかに速い(TLSハンドシェイク分なし) HTTP/2以降はほぼ差なし
ブラウザ警告 「保護されていない通信」 なし

2026年4月時点では、FirefoxはHTTPページでパスワード入力フォームを検知すると強制的に警告を表示します。Chrome系ブラウザも同様の挙動です。


HTTPが現れる主なユースケース

<title id="fig-usecase">HTTPが使われる4つのシーン</title> ローカル開発 localhost 127.0.0.1 内部LB/プロキシ TLS終端後の バックエンド通信 閉域イントラネット VPN内の サービス間通信 IoT/組込み機器 リソース制約が 厳しい環境 外部に出ない → 現実的に許容 同一ホスト内なら → 条件付き許容 ネットワーク設計 次第で許容 要件に応じて 個別判断
HTTPが登場する4つのシーンと判断の方向性

ローカル開発環境

localhost へのアクセスはブラウザセキュリティモデルで「安全なオリジン」扱いです(W3C Secure Contexts)。 実際、http://localhost:3000 で React や Next.js の開発サーバーを立ち上げる構成は珍しくありません。

ただし最初はHTTPで開発して後でHTTPSに切り替えればいいと考えていましたが、実際にはSameSite属性やCookieのSecureフラグ、Content Security PolicyなどをHTTPS前提で設計すると、HTTP環境では動作確認できない挙動が出てきます。可能な限り、開発環境でもHTTPSを再現するほうが後の痛みは少ないと感じています。

ロードバランサーやリバースプロキシの内側

AWS ALBやNginx、EnvoyなどがフロントエンドのTLSを終端し、バックエンドへの転送をHTTPで行う構成は一般的です。この通信はロードバランサーとバックエンドが同一のVPCやコンテナネットワーク内にいることが前提で、外部からの盗聴経路がありません。

余談ですが、この構成はしばしばセキュリティ監査で指摘対象になります。監査者によっては「内部通信もHTTPSにすべき」と言い、開発者は「同一VPCだから問題ない」と主張する——ここは正直、賛否あります。厳密なゼロトラスト設計(NIST SP 800-207)を採用する場合は、内部通信もmTLSが推奨されます。

閉域イントラネットやVPN内のサービス間通信

外部インターネットに接続しない工場の生産管理システムや、企業のオンプレミスサーバー間通信では、証明書管理のコストとメリットを天秤にかけた結果、HTTPが選ばれることがあります。 ここで重要なのは「閉じているから安全」ではなく、内部の侵害者や横断侵害(ラテラルムーブメント)のリスクをどう評価するかです。

IoTや組込み機器

RAM・フラッシュが数百KB〜数MBのMCUでTLSスタックを走らせるのは現実的でない場合があります。 ただし2026年4月時点では、Mbed TLS(旧PolarSSL)など組込み向けの軽量TLS実装が整備されており、「リソースが足りない」は年々言い訳しにくくなっています。


使ってはいけない場面

以下のシナリオでのHTTPは「リスクの受け入れ」ではなく「過失」と判断される可能性があります。

シナリオ 理由
ログイン・認証フォーム パスワードを平文で流す。中間者攻撃で即時漏洩
決済情報の送信 PCI DSS準拠違反。加盟店契約失効のリスク
個人情報の収集フォーム 個人情報保護法・GDPRの安全管理措置義務に抵触しうる
セッションCookieの発行 Secure属性なしのCookieはHTTPで盗聴される
APIトークン・APIキーの送信 ヘッダー平文で流れる
公衆Wi-Fi経由のアクセス想定 経路上のすべてのノードが傍受できる

個人情報保護法については個人情報保護委員会のガイドライン、GDPRについては欧州委員会のGDPRページを参照してください(2026年4月時点)。


判断フロー:HTTPを使っていい場面か確認する

<title id="fig-flow">HTTPを使用してよいか判断するフローチャート</title> Q1. localhost 通信のみか? No Yes 開発環境は許容 → 本番は要再確認 Q2. 個人情報・認証情報を含むか? No Yes HTTPS必須 → Let's Encryptで対応 Q3. 閉域ネットワークのみか? Yes No Q4. 監査対象 or ゼロトラスト? No Yes HTTP 条件付き許容 → リスクを必ず文書化 ※ 迷ったら常にHTTPSを選ぶのが安全。 上記は例外判断の整理
HTTPを使っていいか迷ったら、上から順に4問で結論が出る

Mixed Content問題:HTTPSページにHTTP要素を混在させない

HTTPSで配信されるページ内に、HTTPで読み込むスクリプト・画像・APIリクエストが1つでもあるとMixed Contentが発生します。

  • Passive Mixed Content(画像・動画): ブラウザは警告を出すが読み込む
  • Active Mixed Content(スクリプト・フレーム・XHR/fetch): ブラウザがブロックする

fetch("http://api.example.internal/data") をHTTPSページから呼び出すと、Chromeはネットワーク接続を拒否します。バックエンドが内部HTTPであっても、ブラウザから直接呼び出す場合はHTTPSが必要です。この場合の解決策は、HTTPSで受けるプロキシ(BFF: Backend For Frontend)を挟むことです。


実行可能な次の一歩

現在のプロジェクトを確認するための最小チェックリストです。

  1. Chrome DevToolsのSecurityパネルを開き、Mixed Contentの警告がないか確認する
  2. curl -I http://your-app.example.com を実行し、301 Moved Permanentlyhttps:// へのリダイレクトが返るか確認する
  3. ロードバランサー内部通信のHTTPについて、VPCのセキュリティグループ・ACLで外部からの443以外のアクセスを遮断しているか確認する
  4. 開発環境で mkcert(FiloSottile/mkcert)を使い、ローカルでもHTTPSを有効にする
  5. Cookieに SecureHttpOnly が付いているかDevToolsのApplicationタブで確認する

Webのセキュリティ設定は技術選定やアーキテクチャ判断と密接に絡みます。制度面の管理措置に興味があれば、給与明細の控除項目を読む:社会保険料と税金の仕組みのように「文書が現実を動かす」場面を理解する視点も、セキュリティ文書の整備に役立ちます。


FAQ

Q. 社内システムだからHTTPでいい、という判断は正しいですか? A. ネットワーク構成次第です。インターネットに接続しない完全な閉域ならリスクは低くなりますが、社内PCがVPN経由でアクセスする構成や、クラウド上のプライベートサブネットの場合は「社内」の定義が曖昧です。ゼロトラストの観点では、物理的な境界に依存しない認証・暗号化が推奨されます。

Q. ローカル開発環境もHTTPSにすべきですか? A. できればそうすべきです。mkcert を使えば数分で自己署名証明書を信頼済みにできます。特にSameSite=Strict CookieやHTTPS専用APIを扱う場合は、開発段階からHTTPS環境で再現することでデバッグコストが下がります。

Q. Let’s Encryptの証明書は本当に無料ですか? A. 2026年4月時点では無料です。ただし発行には公開ドメインが必要で、プライベートIPや内部ホスト名には発行できません。その場合はプライベートCAを立てるか、ACMEプロトコルに対応したプライベートCA製品(例


関連する記事

テクノロジー · 9分 · 0

WebページのJPEGとWebP:読み込み速度と画質の差を実測する

TOC 結論: 写真系はWebP、互換性が不安な場面はpictureタグでJPEGをfallback提供すれば両立できる。 Webページの表示速度は、直接的にユーザーの離脱率と検索順位に影響します。そしてページ重量の半分以上を占めることが多いのが画像ファイルです。「とりあえずJPEGで書き出す」という判断をずっと続けて…

テクノロジー · 12分 · 0

WebフォントとシステムフォントのLCPへの影響:読み込み遅延と見た目の変化を測定する

TOC 結論: WebフォントはLCPを平均数百ms悪化させる。fontdisplay戦略とpreloadの組み合わせが最速の改善策。 Webフォントを使えばブランドの個性が出る。しかし何も考えずに導入すると、LCPLargest Contentful Paintスコアが静かに悪化していきます。 その悪化幅は「どうせ誤…

テクノロジー · 9分 · 4

ローカル開発環境とクラウド開発環境、プロジェクト規模で使い分ける判断軸

結論: 3人以下・長期運用ならローカル、4人以上・短命プロジェクトはクラウドが合う。 TOC 開発環境の選択は「どちらが優れているか」という問いではなく、「このプロジェクトに何が合うか」という問いです。 最初は「クラウドなんて大げさ」と思っていたのですが、実際に5人チームでGitHub Codespacesを使い始めて…

テクノロジー · 10分 · 3

Gitコミットの粒度と後悔:何行動で1コミットにすべきか

結論: 「1コミット=1つの論理的変更」。バグ修正とリファクタは必ず分けて積む。 Gitのコミット粒度をどう決めるか——これはコードの品質と同じくらい開発体験に直結する問いです。 「とりあえずまとめてコミット」を続けたある日、障害対応でrevertが必要になり、関係のない変更まで巻き込んでしまった経験は、多くのエンジニ…

テクノロジー · 9分 · 0

ブラウザのタブを閉じるべきタイミング:メモリ消費と生産性の実測値

結論: タブは「用途の終わったものをその場で閉じる」が唯一の正解。保留は後悔の始まりです。 ブラウザのタブは増えるのに、減ることは稀です。気づけば20枚、40枚と積み上がり、PCのファンが唸り始める。しかし実際のところ、タブの枚数は何枚から「問題」になるのでしょうか。そして、生産性への影響は本当に計測できるものなのでし…

テクノロジー · 10分 · 0

APIドキュメントの読み方:必須項目と実装に必要な情報の抽き出し方

結論: 認証・エンドポイント・リクエスト形式・レート制限・エラーコードの5点を先に読めば、実装で詰まる確率は大きく下がる。 APIドキュメントを初めて開いたとき、ページ数の多さと用語の密度に圧倒された経験は多くの人が持っているでしょう。最初から全部読もうとすると、実装に入れないまま1時間が過ぎることもあります。 重要な…

コメント

最初のコメントを残してみませんか。

コメントは承認後に表示されます。