0


使用PHP创建登录界面并连接MySQL数据库

1 编写一个用户登录的界面
<!DOCTYPE html>
<html>
    <meta charset="utf-8">
<body>
<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>
</body>
</html>

2 编写PHP脚本

在接受登录界面发来的请求后,接受并检查用户名用户密码是否正确;

包括连接数据库命令。

<?php
// 告知浏览器我们是html,解码用utf-8,header()表示向客户端发送一个原始的http包头
 header('Content-type:text/html; charset=utf-8');
 // 开启Session,返回一个bool值
 // Session表示存储关于用户会话(session)的信息
 session_start();

 // 处理用户登录信息
 // $_POST[]的变量应该是请求的html页面中,通过‘name’被复制的变量
 if (isset($_POST['login'])) {
    # 接受用户的登录消息,trim去掉字符串中的空格
    $username = trim($_POST['username']);
    $password = trim($_POST['password']);
    // 判断提交的登录信息
    if (($username == '') || ($password == '')) {
        // 若为空,视为未填写,提示错误,并3秒后返回登录界面
        header('refresh:3; url=login.html');
        echo "用户名或密码不能为空,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
        exit;
    } 
    // 连接数据库
    $con = mysqli_connect('localhost', 'root', '123456') ;
    // 验证数据库的连接状态
    if (mysqli_errno($con)) {
        echo "连接失败,请重试".mysqli_error($con);
        exit;
    }
    // 设置解码方式
    mysqli_set_charset($con, 'utf-8');
    // 设置数据库
    mysqli_select_db($con, 'test');
    // 查看输入的用户名用户密码与数据库中的值是否相同
    $sql = "select * from login where username = $username and password = $password";
    $result = mysqli_query($con, $sql);
    $num = mysqli_num_rows($result);
    if (!$num) {
        header('refresh:3; url=login.html');
        echo "用户名或密码错误,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
        exit;
    } else {
        # 用户名和密码都正确,将用户信息存储到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);
        }
        echo "登录成功!";
        mysqli_close($con);
    }
}
?>
3 数据库的创建

(1)记得修改root密码为“123456”,可以在PHPstudy的MySQL工具中重置密码;

(2)创建test数据库,login表格,加入用户名为“username”,密码为“password”的数据。

以下是一些MySQL命令行的语句【命令后必须加分号】:

// 显示当前数据库:
show databases;
// 创建数据库:
create database test;
// 使用数据库:
use test;
// 展示当前数据库内容:
show tables;
// 创建新的表格login,并给出格式:
create table login(username char(20), password char(20));
// 插入数据:
insert into login values(“username”, “password”);
// 展示表格所有数据:
select * from login;

4 在浏览器中测试

(1) 输入正确的用户名,错误的密码:

(2)输入正确的用户名和密码:

标签: 数据库 php mysql

本文转载自: https://blog.csdn.net/Cathy121381314/article/details/132797304
版权归原作者 一棵纯白菜 所有, 如有侵权,请联系我们删除。

“使用PHP创建登录界面并连接MySQL数据库”的评论:

还没有评论