1.密码输入错误次数过多
前端代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
</head>
<body>
<table width="300">
<form action="login.php" method="post">
<tr>
<td colspan="2" align="center">用户登录</td>
</tr>
<tr>
<td>用户名</td>
<td><input type="text" name="name"></td>
</tr>
<tr>
<td>密码</td>
<td><input type="password" name="password"></td>
</tr>
<tr>
<td></td>
<td><input type="submit" value="登录"></td>
</tr>
</form>
</table>
</body>
</html>
后端代码
<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
//定义一个用户名和密码
$name='xiaobao';
$pw = '123456';
//接收传递的用户名和密码
$name = $_POST['name'];
$password = $_POST['password'];
//判断密码输错了几次
$flag = $redis->get($name);
$tim = $redis->TTL($name);
$time =round($tim/60,0);
if($flag>=5){
echo "密码错误已超过5次,请 $time 分钟后重试";
exit;
}
//验证密码
if($pw==$password){
//密码正确
echo '密码正确,欢迎登录';
}else{
//密码输入错误,记录错误次数,使用redis的字符串类型来记录
//键的名称是登录名
$redis->incr($name);
//给$name键设置有效期
$redis->setTimeout($name,1800);
echo '密码错误';
}
<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
//把库存信息添加到链表中
$goods_nuber=100;
for($i=0;$i<100;$i++){
$redis->lpush('goods_store',1);
}
//echo 'ok';
?>
2.秒杀功能
<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
//把库存信息添加到链表中
$goods_nuber=100;
for($i=0;$i<100;$i++){
$redis->lpush('goods_store',1);
}
<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
//设置goods_store链表的缓存周期
$redis->setTimeout('goods_store',30);
<?php
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
//判断库存是否充足
//lpop 是从链表头部删除一个元素,并返回该元素值
$res = $redis->lpop('goods_store');
if($res){
echo 'success';
//跳转到下单页面
}else{
echo 'fail';
}