使用PHP创建登录界面并连接MySQL数据库
admin 阅读: 2024-03-16
后台-插件-广告管理-内容页头部广告(手机) |
1 编写一个用户登录的界面
- 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.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。
在线投稿:投稿 站长QQ:1888636
后台-插件-广告管理-内容页尾部广告(手机) |