PHPでHTMLページへのログインジャンプ機能を実装する方法
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(); } ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Login</title> <style> body{ font: 14px sans-serif; } .wrapper{ width: 350px; padding: 20px; } </style> </head> <body> <div class="wrapper"> <h2>Login</h2> <p>Please fill in your credentials to login.</p> <form action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>" method="post"> <div <?php echo (!empty($username_err)) ? 'has-error' : ''; ?>"> <label>Username</label> <input type="text" name="username" class="form-control" value="<?php echo $username; ?>"> <span <?php echo (!empty($username_err)) ? 'help-block' : ''; ?>"><?php echo $username_err; ?></span> </div> <div <?php echo (!empty($password_err)) ? 'has-error' : ''; ?>"> <label>Password</label> <input type="password" name="password" class="form-control"> <span <?php echo (!empty($password_err)) ? 'help-block' : ''; ?>"><?php echo $password_err; ?></span> </div> <div class="form-group"> <input type="submit" class="btn btn-primary" value="Login"> </div> <p>Don't have an account? <a href="register.html">Sign up now</a>.</p> </form> </div> </body> </html>
上記は、ユーザー ログインが 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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









