使用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)输入正确的用户名和密码:

   

  • 3
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
抱歉,作为AI语言模型,我无法执行实际的编程操作。但是,我可以为您提供一个基本的用户登录页面的示例,并提供一些有关如何连接数据库的信息。 用户登录页面示例: ```html <!DOCTYPE html> <html> <head> <title>User Login</title> </head> <body> <h1>User Login</h1> <form method="post" action="login.php"> <label for="username">Username:</label> <input type="text" name="username" required><br><br> <label for="password">Password:</label> <input type="password" name="password" required><br><br> <input type="submit" value="Login"> </form> </body> </html> ``` 此页面包含一个表单,其中包含用户名和密码字段,以及一个提交按钮。表单将数据提交到名为“login.php”的处理程序。 要连接数据库,您需要使用特定的编程语言和数据库系统。下面是使用PHPMySQL数据库的示例代码: ```php <?php // 定义数据库连接参数 $host = "localhost"; $username = "your_username"; $password = "your_password"; $database = "your_database"; // 创建数据库连接 $conn = mysqli_connect($host, $username, $password, $database); // 检查连接是否成功 if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } // 处理用户登录请求 if ($_SERVER["REQUEST_METHOD"] == "POST") { $username = $_POST["username"]; $password = $_POST["password"]; // 查询用户信息 $sql = "SELECT * FROM users WHERE username = '$username' AND password = '$password'"; $result = mysqli_query($conn, $sql); // 检查查询结果 if (mysqli_num_rows($result) == 1) { // 登录成功 header("Location: welcome.php"); } else { // 登录失败 echo "Invalid username or password."; } } // 关闭数据库连接 mysqli_close($conn); ?> ``` 此代码将连接到一个名为“your_database”的MySQL数据库,并从名为“users”的表中检索用户信息。如果用户输入的用户名和密码与数据库中的记录匹配,则将用户重定向到“welcome.php”页面,否则将显示错误消息。 请注意,此示例仅用于演示目的,并不是完整的、可用于生产环境的代码。在实际应用程序中,您应该采用更好的安全措施,例如使用哈希密码和预处理语句来防止SQL注入攻击。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一棵纯白菜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值