はじめに
この実験では、カスタム 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+X、Y、Enter の順にキーを押してファイルを保存し、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+X、Y、Enter を押して変更を保存し、エディタを終了します。これで、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 スタイルが正しく適用されていることを確認します。
ラボ環境の右側には、デスクトップインターフェースが表示されます。Web ブラウザアイコンをクリックして開きます。
ブラウザのアドレスバーに、次の URL を入力して
Enterを押します。http://127.0.0.1:8000
これで、カスタムログインページが表示されるはずです。プレーンでスタイルが適用されていないページではなく、薄い灰色の背景、影付きの白い中央揃えのログインボックス、スタイル設定された入力フィールド、青いログインボタンが表示されるはずです。これにより、style.css ファイルが正常にリンクされ、適用されたことが確認できます。
外観を確認したら、Python サーバーが実行されているターミナルに戻り、Ctrl+C を押して停止します。
まとめ
この実験では、カスタム CSS スタイルシートを統合して、基本的なキャプティブポータルを正常に強化しました。スタイルを管理するための個別の .css ファイルの作成方法、特定の HTML 要素をターゲットにするための CSS ルールの記述方法、および <link> タグを使用したスタイルシートの HTML ドキュメントへのリンク方法を学びました。ローカル Web サーバーで作業をプレビューすることにより、スタイリングの即時の影響を確認し、プレーンなページを視覚的に魅力的でより説得力のあるログインフォームに変えることができました。このスキルは Web 開発の基本であり、効果的なカスタムキャプティブポータルを作成するために不可欠です。
