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