• 技术文章 >后端开发 >php教程

    php实现简单的登陆功能(附源码)

    烟雨青岚烟雨青岚2020-06-09 10:17:53转载1914

    php实现简单的登陆功能(附源码)

    在一个网站中登陆功能是必不可少的,本文简单的讲述了在php中如何实现登陆功能。

    登录界面:

    denglu.png

    html代码(login.html):

    <form action="login.php" method="post">
    <fieldset>
    <legend>用户登录</legend>
    <ul>
    <li>
    <label>用户名:</label>
    <input type="text" name="username">
    </li>
    <li>
    <label>密   码:</label>
    <input type="password" name="password">
    </li>
    <li>
    <label> </label>
    <input type="checkbox" name="remember" value="yes">7天内自动登录
    </li>
    <li>
    <label> </label>
    <input type="submit" name="login" value="登录">
    </li>
    </ul>
    </fieldset>
    </form>

    login.php:(登陆处理页)

    <?php 
    header('Content-type:text/html; charset=utf-8');
    // 开启Session
    session_start();
     
    // 处理用户登录信息
    if (isset($_POST['login'])) {
    # 接收用户的登录信息
    $username = trim($_POST['username']);
    $password = trim($_POST['password']);
    // 判断提交的登录信息
    if (($username == '') || ($password == '')) {
    // 若为空,视为未填写,提示错误,并3秒后返回登录界面
    header('refresh:3; url=login.html');
    echo "用户名或密码不能为空,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
    exit;
    } elseif (($username != 'username') || ($password != 'password')) {
    # 用户名或密码错误,同空的处理方式
    header('refresh:3; url=login.html');
    echo "用户名或密码错误,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
    exit;
    } elseif (($username = 'username') && ($password = 'password')) {
    # 用户名和密码都正确,将用户信息存到Session中
    $_SESSION['username'] = $username;
    $_SESSION['islogin'] = 1;
    // 若勾选7天内自动登录,则将其保存到Cookie并设置保留7天
    if ($_POST['remember'] == "yes") {
    setcookie('username', $username, time()+7*24*60*60);
    setcookie('code', md5($username.md5($password)), time()+7*24*60*60);
    } else {
    // 没有勾选则删除Cookie
    setcookie('username', '', time()-999);
    setcookie('code', '', time()-999);
    }
    // 处理完附加项后跳转到登录成功的首页
    header('location:index.php');
    }
    }
     ?>

    index.php(默认主页):

    <?php 
    header('Content-type:text/html; charset=utf-8');
    // 开启Session
    session_start();
     
    // 首先判断Cookie是否有记住了用户信息
    if (isset($_COOKIE['username'])) {
    # 若记住了用户信息,则直接传给Session
    $_SESSION['username'] = $_COOKIE['username'];
    $_SESSION['islogin'] = 1;
    }
    if (isset($_SESSION['islogin'])) {
    // 若已经登录
    echo "你好! ".$_SESSION['username'].' ,欢迎来到个人中心!<br>';
    echo "<a href='logout.php'>注销</a>";
    } else {
    // 若没有登录
    echo "您还没有登录,请<a href='login.html'>登录</a>";
    }
     ?>

    logout.php注销页

    <?php 
    header('Content-type:text/html; charset=utf-8');
    // 注销后的操作
    session_start();
    // 清除Session
    $username = $_SESSION['username'];  //用于后面的提示信息
    $_SESSION = array();
    session_destroy();
     
    // 清除Cookie
    setcookie('username', '', time()-99);
    setcookie('code', '', time()-99);
     
    // 提示信息
    echo "欢迎下次光临, ".$username.'<br>';
    echo "<a href='login.html'>重新登录</a>";
     
     ?>

    登录成功的状态:

    01.png

    若勾选7天内自动登录,则会将登录信息通过Cookie和Session技术保存在本地Cookie文件中,7天内会自动登录。

    注销页面:

    01.png

    登录错误的几种情况都做了处理:

    02.jpg

    感谢大家的阅读,希望大家有所收益。

    本文转自:https://blog.csdn.net/l269798518/article/details/80462216

    推荐教程:《PHP教程

    以上就是php实现简单的登陆功能(附源码)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:CSDN,如有侵犯,请联系admin@php.cn删除
    专题推荐:php 登陆功能
    上一篇:PHP使用JWT创建Token的实例详解 下一篇:详解PHP中password_hash的功能
    线上培训班

    相关文章推荐

    • use关键字在php中的使用(含代码)• PHP session_register函数(附详解)• php命名格式注意事项(详解)• php实现简单的留言板功能(附源码)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网