ホームページ > バックエンド開発 > PHPの問題 > PHP でパスワード変更と終了ページを実装する方法を説明する例

PHP でパスワード変更と終了ページを実装する方法を説明する例

PHPz
リリース: 2023-04-03 20:16:02
オリジナル
1116 人が閲覧しました

PHP は広く使用されているスクリプト言語で、Web 開発に非常に適しており、パスワード変更や終了ページでもその利点を発揮します。この記事では、PHP でパスワード変更と終了ページを実装する方法に焦点を当てます。

1. パスワード変更ページ

ユーザーがパスワードを変更したい場合は、まずパスワード変更ページに移動し、元のパスワードと新しいパスワードを入力させる必要があります。 PHP では、$_POST 変数を使用して、ユーザーが送信したデータを受け取ることができます。コードは次のとおりです:

<?php
session_start();
if(isset($_SESSION[&#39;username&#39;])) { //判断用户是否已登录
    if(isset($_POST[&#39;submit&#39;])) { //判断是否提交了表单
        $old_password = md5($_POST[&#39;old_password&#39;]); //将原密码加密
        $new_password = md5($_POST[&#39;new_password&#39;]); //将新密码加密
        //根据实际情况修改用户名和密码所对应的字段名
        $conn = mysqli_connect(&#39;localhost&#39;, &#39;root&#39;, &#39;123456&#39;, &#39;test&#39;);
        $sql = "SELECT username, password FROM users WHERE username=&#39;{$_SESSION[&#39;username&#39;]}&#39; AND password=&#39;{$old_password}&#39;";
        $result = mysqli_query($conn, $sql);
        if(mysqli_num_rows($result) == 1) { //如果查询结果为一条数据,说明原密码正确
            $sql = "UPDATE users SET password=&#39;{$new_password}&#39; WHERE username=&#39;{$_SESSION[&#39;username&#39;]}&#39;";
            $result = mysqli_query($conn, $sql);
            if($result) {
                echo &#39;密码修改成功!&#39;;
            } else {
                echo &#39;密码修改失败!&#39;;
            }
        } else {
            echo &#39;原密码错误!&#39;;
        }
    }
}
?>
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>密码修改</title>
</head>
<body>
    <form action="" method="post">
        <label for="old_password">原密码:</label>
        <input type="password" name="old_password" id="old_password"><br>
        <label for="new_password">新密码:</label>
        <input type="password" name="new_password" id="new_password"><br>
        <input type="submit" name="submit" value="提交">
    </form>
</body>
</html>
ログイン後にコピー

上記のコードでは、まずユーザーが次のとおりであるかどうかを確認します。ログインしていない場合は、パスワードを変更できません。次に、$_POST 変数を介してフォームから送信された元のパスワードと新しいパスワードを受け取り、元のパスワードとデータベースに保存されているパスワードを比較します。同じであれば、パスワードを更新します。同じでなければ、パスワードを更新します。元のパスワードが間違っているというプロンプトが表示されます。

2. 終了ページ

Web アプリケーションでは通常、ユーザーが現在のセッションを安全に終了できるように終了ページが提供されます。 PHP では、session_destroy() 関数を使用して現在のセッションを破棄し、ログイン ページにジャンプできます。コードは次のとおりです。

<?php
session_start();
session_destroy();
header(&#39;location: login.php&#39;);
?>
ログイン後にコピー

上記のコードでは、最初にセッションを開始し、次に session_destroy() 関数を使用して現在のセッションを破棄し、最後に header() 関数 ログインページにジャンプします。

概要

この記事では、PHP でパスワード変更と終了ページを実装する方法を学びました。これらの機能は、フォームの送信とセッションの処理を通じて簡単に実装できます。もちろん、実際のアプリケーションでは、プログラムの安定性とセキュリティを確保するために、エラーとセキュリティの問題をより慎重に処理する必要があります。

以上がPHP でパスワード変更と終了ページを実装する方法を説明する例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート