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

   

  • 1
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: PHP是一种流行的编程语言,它可以用于开发动态网页。利用PHP可以轻松地创建一个数据库登录注册页面。 首先,我们需要创建一个数据库来存储用户的注册信息。可以使用MySQL作为数据库管理系统,使用phpMyAdmin进行数据库创建和管理。在数据库中,我们可以创建一个名为“users”的表来存储用户的信息,包括用户名、密码等字段。 接下来,我们可以创建一个名为“register.php”的文件作为注册页面。在这个页面上,我们可以设置一些输入框,用户可以在这里输入他们的用户名和密码。当用户点击“注册”按钮时,我们可以使用PHP代码来处理用户的输入,并将其插入到“users”表中。 当用户点击注册按钮时,我们可以使用PHP代码来验证用户的输入是否有效。我们可以使用一些验证函数,例如`filter_var()`来验证用户的电子邮件地址或使用`preg_match()`来验证用户名是否符合一定的规则。如果用户的输入无效,可以向用户显示错误消息,并要求他们重新输入。 如果用户的输入有效,我们可以使用SQL INSERT语句将用户的信息插入到“users”表中。我们可以使用PHP提供的数据库函数,如`mysqli_query()`来执行SQL语句。插入成功后,我们可以向用户显示一条成功消息,并可以选择直接将用户重定向到登录页面。 在登录页面上,“login.php”,我们需要让用户输入他们的用户名和密码。当用户点击“登录”按钮时,我们可以使用PHP代码来查询“users”表,检查用户提供的用户名和密码是否与数据库中的匹配。如果匹配成功,我们可以向用户显示一条成功消息,并可以选择将用户重定向到他们的个人资料页面。如果匹配失败,我们可以向用户显示错误消息,并要求他们重新输入。 通过使用以上的步骤,我们可以创建一个简单的PHP数据库登录注册页面。当用户成功注册后,他们可以使用他们的用户名和密码登录到系统中。 ### 回答2: 在PHP中,创建数据库登录注册页面是非常常见和重要的任务。以下是一个简单的示例代码: 1. 首先,我们需要创建一个用于连接数据库连接对象。可以使用mysqli扩展来完成这一任务,如下所示: ```php $servername = "localhost"; $username = "root"; $password = "password"; $dbname = "database_name"; $conn = new mysqli($servername, $username, $password, $dbname); // 检查连接是否成功 if ($conn->connect_error) { die("连接失败:" . $conn->connect_error); } ``` 2. 创建一个用于用户注册的页面。在这个页面上,我们将显示一个表单,要求用户输入用户名和密码,并将其保存到数据库中。代码如下: ```php if(isset($_POST['submit'])){ $username = $_POST['username']; $password = $_POST['password']; // 验证用户输入的数据 // 插入数据到数据库 $sql = "INSERT INTO users (username, password) VALUES ('$username', '$password')"; if ($conn->query($sql) === TRUE) { echo "注册成功"; } else { echo "注册失败:" . $conn->error; } } // HTML表单 <form method="post" action=""> 用户名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> <input type="submit" name="submit" value="注册"> </form> ``` 3. 创建一个用于用户登录的页面。在这个页面上,我们将显示一个表单,要求用户输入用户名和密码,并验证其是否在数据库中存在。代码如下: ```php if(isset($_POST['submit'])){ $username = $_POST['username']; $password = $_POST['password']; // 验证用户输入的数据 // 查询数据库 $sql = "SELECT * FROM users WHERE username='$username' AND password='$password'"; $result = $conn->query($sql); if ($result->num_rows > 0) { echo "登录成功"; } else { echo "登录失败"; } } // HTML表单 <form method="post" action=""> 用户名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> <input type="submit" name="submit" value="登录"> </form> ``` 以上代码是一个简单的PHP数据库登录注册页面示例。可以根据实际需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一棵纯白菜

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

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

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

打赏作者

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

抵扣说明:

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

余额充值