キャプティブポータルにカスタム CSS スタイルシートを統合する

Beginner
オンラインで実践に進む

はじめに

この実験では、カスタム Cascading Style Sheets (CSS) ファイルをキャプティブポータルの index.html ファイルに統合する方法を学びます。基本的な HTML ページでも機能しますが、カスタムスタイルを適用することで、よりプロフェッショナルで説得力のある外観になります。style.css ファイルを作成し、スタイリングルールを追加してから、HTML ドキュメントにリンクしてログインページの表示を変換します。

カスタムポータルのディレクトリを開く

このステップでは、カスタムポータルファイルが格納されているディレクトリに移動します。新しいファイルの作成や既存のファイルの編集など、すべての作業はこのディレクトリ内で行います。

まず、cd (change directory) コマンドを使用して、プロジェクトフォルダ内の custom_portal ディレクトリに移動します。

cd ~/project/custom_portal

次に、ls -l コマンドを使用してディレクトリの内容を一覧表示します。これにより、正しい場所にいることを確認し、これから作業する index.html ファイルが表示されます。

ls -l

以下のような出力が表示され、index.html ファイルが存在することを確認できます。

total 4
-rw-r--r-- 1 labex labex 483 Dec 01 12:00 index.html

CSS ルールを含む 'style.css' ファイルを作成する

このステップでは、ログインページのビジュアルスタイルを定義するための CSS ファイルを作成します。CSS を使用すると、HTML 要素のレイアウト、色、フォント、および全体的な外観を制御できます。

nano テキストエディタを使用して、style.css という名前のファイルを作成します。

nano style.css

nano エディタが開いたら、以下の CSS コードをファイルにコピー&ペーストします。このコードは、さまざまな HTML 要素をターゲットにして、クリーンでモダンなログインフォームのデザインを作成します。

body {
  font-family: Arial, sans-serif;
  background-color: #f0f2f5;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  margin: 0;
}

.login-container {
  background-color: #ffffff;
  padding: 30px;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  text-align: center;
  width: 320px;
}

h1 {
  font-size: 24px;
  margin-bottom: 20px;
  color: #333;
}

input[type="text"],
input[type="password"] {
  width: 100%;
  padding: 12px;
  margin-bottom: 15px;
  border: 1px solid #ddd;
  border-radius: 6px;
  box-sizing: border-box;
}

button {
  width: 100%;
  padding: 12px;
  background-color: #007bff;
  color: white;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 16px;
  font-weight: bold;
}

button:hover {
  background-color: #0056b3;
}

コードを貼り付けたら、Ctrl+XYEnter の順にキーを押してファイルを保存し、nano を終了します。

'index.html' ファイルにスタイルシートをリンクする

このステップでは、新しく作成した style.css ファイルを index.html ファイルにリンクします。スタイルシートを作成するだけでは不十分です。HTML ドキュメントにそれを使用するように指示する必要があります。これは、HTML の <head> セクション内に <link> タグを追加することで行われます。

nano エディタで index.html ファイルを開きます。

nano index.html

ファイルの <head> セクションに移動します。閉じタグ </head> の直前に、次の行を追加します。

<link rel="stylesheet" href="style.css" />

これで、index.html ファイルは次のようになります。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>WiFi Login</title>
    <link rel="stylesheet" href="style.css" />
  </head>
  <body>
    <div class="login-container">
      <h1>Please Log In to Access the Internet</h1>
      <form action="#" method="post">
        <p>Username:</p>
        <input
          type="text"
          name="username"
          placeholder="Enter your username"
          required
        />
        <p>Password:</p>
        <input
          type="password"
          name="password"
          placeholder="Enter your password"
          required
        />
        <br /><br />
        <button type="submit">Log In</button>
      </form>
    </div>
  </body>
</html>

Ctrl+XYEnter を押して変更を保存し、エディタを終了します。これで、HTML ページがスタイルシートにリンクされ、ページをレンダリングするブラウザはすべて CSS ルールを適用します。

カスタムポータルで攻撃を開始する

このステップでは、スタイル設定されたキャプティブポータルページをプレビューします。完全なネットワーク攻撃を開始する代わりに、単純な Python Web サーバーを使用してファイルをローカルでホストします。これにより、ページがユーザーにどのように表示されるかを正確に確認できます。

まだ ~/project/custom_portal ディレクトリにいることを確認してください。次のコマンドを実行して、ポート 8000 で Web サーバーを起動します。

python3 -m http.server 8000

このコマンドは、Python に組み込みの http.server モジュールを実行するように指示します。これは、現在のディレクトリ (custom_portal) からファイルをサーブします。サーバーは、ポート 8000 でローカルマシンからアクセス可能になります。

ターミナルには、サーバーが実行中であることを示すメッセージが表示されます。

Serving HTTP on 0.0.0.0 port 8000 (http://0.0.0.0:8000/) ...

サーバーは現在アクティブです。このターミナルを実行したまま、次のステップに進んでページを表示してください。

ログインページにカスタムスタイルが適用されていることを確認する

この最終ステップでは、Web ブラウザでログインページを表示して、CSS スタイルが正しく適用されていることを確認します。

  1. ラボ環境の右側には、デスクトップインターフェースが表示されます。Web ブラウザアイコンをクリックして開きます。

  2. ブラウザのアドレスバーに、次の URL を入力して Enter を押します。

    http://127.0.0.1:8000
    

これで、カスタムログインページが表示されるはずです。プレーンでスタイルが適用されていないページではなく、薄い灰色の背景、影付きの白い中央揃えのログインボックス、スタイル設定された入力フィールド、青いログインボタンが表示されるはずです。これにより、style.css ファイルが正常にリンクされ、適用されたことが確認できます。

外観を確認したら、Python サーバーが実行されているターミナルに戻り、Ctrl+C を押して停止します。

まとめ

この実験では、カスタム CSS スタイルシートを統合して、基本的なキャプティブポータルを正常に強化しました。スタイルを管理するための個別の .css ファイルの作成方法、特定の HTML 要素をターゲットにするための CSS ルールの記述方法、および <link> タグを使用したスタイルシートの HTML ドキュメントへのリンク方法を学びました。ローカル Web サーバーで作業をプレビューすることにより、スタイリングの即時の影響を確認し、プレーンなページを視覚的に魅力的でより説得力のあるログインフォームに変えることができました。このスキルは Web 開発の基本であり、効果的なカスタムキャプティブポータルを作成するために不可欠です。