PHP で HTML ページへのログイン ジャンプを実装するには、基本的なプログラミング スキルを使用する必要があります。このプロセスを実装するための具体的な手順は次のとおりです。
- ログイン ページの作成
まず、ユーザーのログイン資格情報を収集するためのログイン ページを作成する必要があります。このページは、ユーザーの資格情報を確認し、ログインしているユーザーを他の保護されたページに参照するために使用されます。
- ログイン検証ロジックの設定
PHP では、ユーザーが入力した資格情報が有効かどうかを検証する検証ロジックを作成できます。この機能は、MySQL データベースと PHP セッションを使用して実現できます。具体的な手順は次のとおりです。
- ユーザーが入力したユーザー名とパスワードを記録します。
- ユーザー名とパスワードを、MySQL データベースに保存されているアカウント情報と比較します。
- 入力されたユーザー名とパスワードがデータベースと一致する場合、ユーザー資格情報は PHP のセッション変数に保存され、保護されたページにリダイレクトされます。
- 入力されたユーザー名とパスワードが一致しない場合は、ユーザーにエラー メッセージが表示されます。
検証ロジックのコード例は次のとおりです:
<?php // Start the session session_start(); // Check if the user is already logged in if(isset($_SESSION["loggedin"]) && $_SESSION["loggedin"] === true){ header("location: welcome.php"); exit; } // Include config file require_once "config.php"; // Define variables and initialize with empty values $username = $password = ""; $username_err = $password_err = ""; // Processing form data when form is submitted if($_SERVER["REQUEST_METHOD"] == "POST"){ // Check if username is empty if(empty(trim($_POST["username"]))){ $username_err = "Please enter username."; } else{ $username = trim($_POST["username"]); } // Check if password is empty if(empty(trim($_POST["password"]))){ $password_err = "Please enter your password."; } else{ $password = trim($_POST["password"]); } // Validate credentials if(empty($username_err) && empty($password_err)){ // Prepare a select statement $sql = "SELECT id, username, password FROM users WHERE username = ?"; if($stmt = $mysqli->prepare($sql)){ // Bind variables to the prepared statement as parameters $stmt->bind_param("s", $param_username); // Set parameters $param_username = $username; // Attempt to execute the prepared statement if($stmt->execute()){ // Store result $stmt->store_result(); // Check if username exists, if yes then verify password if($stmt->num_rows == 1){ // Bind result variables $stmt->bind_result($id, $username, $hashed_password); if($stmt->fetch()){ if(password_verify($password, $hashed_password)){ // Password is correct, so start a new session session_start(); // Store data in session variables $_SESSION["loggedin"] = true; $_SESSION["id"] = $id; $_SESSION["username"] = $username; // Redirect user to welcome page header("location: welcome.php"); } else{ // Display an error message if password is not valid $password_err = "The password you entered was not valid."; } } } else{ // Display an error message if username doesn't exist $username_err = "No account found with that username."; } } else{ echo "Oops! Something went wrong. Please try again later."; } } // Close statement $stmt->close(); } // Close connection $mysqli->close(); } ?>
- 保護された HTML ページの作成
PHP では、セッション変数を使用できます。ユーザーがログインしているかどうかを確認します。ユーザーがログインしている場合は、保護された HTML ページを表示できます。それ以外の場合は、ログイン ページへのリダイレクトが必要です。
- ログイン ページに PHP コードを追加する
ログイン ページでは、PHP コードを使用してフォームの送信と検証を処理できます。具体的な手順は次のとおりです。
- ユーザー資格情報を送信するフォームを作成します。
- フォームを送信するときは、ユーザーが入力した資格情報が有効であることを確認し、保護されたページにリダイレクトするか、エラー メッセージを表示します。
- ユーザーがすでにログインしている場合は、ログイン フォームを表示する代わりに、保護されたページに自動的にリダイレクトします。
以下は、ログイン フォームと PHP コードを含むサンプル コードです:
<?php // Initialize the session session_start(); // Check if the user is already logged in, if yes then redirect him to welcome page if(isset($_SESSION["loggedin"]) && $_SESSION["loggedin"] === true){ header("location: welcome.html"); exit; } // Include config file require_once "config.php"; // Define variables and initialize with empty values $username = $password = ""; $username_err = $password_err = ""; // Processing form data when form is submitted if($_SERVER["REQUEST_METHOD"] == "POST"){ // Check if username is empty if(empty(trim($_POST["username"]))){ $username_err = "Please enter username."; } else{ $username = trim($_POST["username"]); } // Check if password is empty if(empty(trim($_POST["password"]))){ $password_err = "Please enter your password."; } else{ $password = trim($_POST["password"]); } // Validate credentials if(empty($username_err) && empty($password_err)){ // Prepare a select statement $sql = "SELECT id, username, password FROM users WHERE username = ?"; if($stmt = $mysqli->prepare($sql)){ // Bind variables to the prepared statement as parameters $stmt->bind_param("s", $param_username); // Set parameters $param_username = $username; // Attempt to execute the prepared statement if($stmt->execute()){ // Store result $stmt->store_result(); // Check if username exists, if yes then verify password if($stmt->num_rows == 1){ // Bind result variables $stmt->bind_result($id, $username, $hashed_password); if($stmt->fetch()){ if(password_verify($password, $hashed_password)){ // Password is correct, so start a new session session_start(); // Store data in session variables $_SESSION["loggedin"] = true; $_SESSION["id"] = $id; $_SESSION["username"] = $username; // Redirect user to welcome page header("location: welcome.html"); } else{ // Display an error message if password is not valid $password_err = "The password you entered was not valid."; } } } else{ // Display an error message if username doesn't exist $username_err = "No account found with that username."; } } else{ echo "Oops! Something went wrong. Please try again later."; } } // Close statement $stmt->close(); } // Close connection $mysqli->close(); } ?> nbsp;html> <meta> <title>Login</title> <style> body{ font: 14px sans-serif; } .wrapper{ width: 350px; padding: 20px; } </style> <div> <h2 id="Login">Login</h2> <p>Please fill in your credentials to login.</p> <form>" method="post"> <div>"> <label>Username</label> <input>"> <span>"><?php echo $username_err; ?></span> </div> <div>"> <label>Password</label> <input> <span>"><?php echo $password_err; ?></span> </div> <div> <input> </div> <p>Don't have an account? <a>Sign up now</a>.</p> </form> </div>
上記は、ユーザー ログインが PHP を通じて HTML ページにジャンプするための基本的な手順とコード例です。 。
以上がPHPでHTMLページへのログインジャンプ機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

メモ帳++7.3.1
使いやすく無料のコードエディター

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 中国語版
中国語版、とても使いやすい

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。
