您的位置:首页 > 数据库 > Redis

mark--[Redis用户添加、分页、登录、注册、加关注案例]

2015-08-16 13:09 573 查看
连接redis代码redis.php

<?php
//实例化
$redis = new Redis();
//连接服务器
$redis->connect("localhost");
//授权
$redis->auth("lamplijie");


说明:这是入口文件,使用redis数据库必须先引入它。这样才能用php操作redis数据库。

列表页list.php

<a href="add.php">注册</a>
<?php
require("redis.php");
if(!empty($_COOKIE['auth'])){
$id = $redis->get("auth:".$_COOKIE['auth']);
$name = $redis->hget("user:".$id,"username");
?>
欢迎您,<?php echo $name?>,<a href="logout.php">退出</a>

<?php
}else{
?>

<a href="login.php">登陆</a>
<?php
}
//用户总数
$count = $redis->lsize("uid");

//页大小
$page_size = 3;

//当前页码
$page_num = (!empty($_GET['page']))?$_GET['page']:1;

//页总数
$page_count = ceil($count/$page_size);

$ids = $redis->lrange("uid",($page_num-1)*$page_size,(($page_num-1)*$page_size+$page_size-1));

//var_dump($ids);

/*for($i=1;$i<=($redis->get("userid"));$i++){
$data[] = $redis->hgetall("user:".$i);
}*/
foreach($ids as $v){
$data[] = $redis->hgetall("user:".$v);
}
//var_dump($data);
//$data = array_filter($data);
?>
<table border=1>
<tr>
<th>uid</th>
<th>username</th>
<th>age</th>
<th>操作</th>
<tr>
<?php foreach($data as $v){?>
<tr>
<td><?php echo  $v['uid']?></td>
<td><?php echo  $v['username']?></td>
<td><?php echo  $v['age']?></td>
<td><a href="del.php?id=<?php echo $v['uid']?>">删除</a> <a href="mod.php?id=<?php echo $v['uid']?>">编辑</a>

<?php if(!empty($_COOKIE['auth'])&&$id!=$v['uid']){?>
<a href="addfans.php?id=<?php echo $v['uid']?>&uid=<?php echo $id?>">加关注</a></td>
<?php }?>
</tr>
<?php }?>
<tr>
<td colspan="4">
<a href="?page=<?php echo (($page_num-1)<=1)?1:($page_num-1)  ?>">上一页</a>
<a href="?page=<?php echo (($page_num+1)>=$page_count)?$page_count:($page_num+1)  ?>">下一页</a>
<a href="?page=1">首页</a>
<a href="?page=<?php echo $page_count?>">尾页</a>
当前<?php echo $page_num?>页
总共<?php echo $page_count?>页
总共<?php echo $count?>个用户
</td>
</tr>
</table>

<table border=1>
<caption>我关注了谁</caption>
<?php
$data = $redis->smembers("user:".$id.":following");
foreach($data as $v){
$row = $redis->hgetall("user:".$v);
?>
<tr>
<td><?php echo $row['uid']?></td>
<td><?php echo $row['username']?></td>
<td><?php echo $row['age']?></td>
</tr>
<?php
}
?>
</table>

<table border=1>
<caption>我的粉丝</caption>
<?php
$data = $redis->smembers("user:".$id.":followers");
foreach($data as $v){
$row = $redis->hgetall("user:".$v);
?>
<tr>
<td><?php echo $row['uid']?></td>
<td><?php echo $row['username']?></td>
<td><?php echo $row['age']?></td>
</tr>
<?php
}
?>
</table>


说明:相关功能和连接都在这里体现出来

添加静态页add.php

<form action="reg.php" method="post">
用户名:<input type="text" name="username" /><br />
密码:<input type="password" name="password" /><br />
年龄:<input type="text" name="age" /><br />
<input type="submit" value="注册" />
<input type="reset" value="重新填写" />
</form>


说明:注册页面,很简洁,提供用户名,密码等让用户注册。完了到reg页面中保存处理。

处理添加页reg.php

<?php
require("redis.php");
$username = $_POST['username'];
$password = md5($_POST['password']);
$age = $_POST['age'];
$uid = $redis->incr("userid");
$redis->hmset("user:".$uid,array("uid"=>$uid,"username"=>$username,"password"=>$password,"age"=>$age));
$redis->rpush("uid",$uid);
$redis->set("username:".$username,$uid);
header("location:list.php");


说明:注册成功后,也就是添加成功后跳转到list页面,这是一般的流程,在这里有所体现。这里是选择用hash来保存用户信息,类似于sql中的表。同时将id保存到队列中,方便分页的时候统计个数。

修改静态页mod.php

<?php
require("redis.php");
$uid = $_GET['id'];
$data = $redis->hgetall("user:".$uid);
?>
<form action="doedit.php" method="post">
<input type="hidden" value="<?php echo $data['uid']?>" name="uid" />
用户名:<input type="text" name="username" value="<?php echo $data['username']?>" /><br />
年龄:<input type="text" name="age" value="<?php echo $data['age']?>" /><br />
<input type="submit" value="修改" />
<input type="reset" value="重新填写" />
</form>


说明:修改页面,首先获取id,用了hgetall方法,获取用户信息并展示出来。

处理添加信息页doedit.php

<?php
require("redis.php");
$uid = $_POST['uid'];
$username = $_POST['username'];
$age = $_POST['age'];
$a = $redis->hmset("user:".$uid,array("username"=>$username,"age"=>$age));
if($a){
header("location:list.php");
}else{
header("location:mod.php?id=".$uid);
}


说明:通过post获取信息,并且修改之hmset,修改成功进行跳转。

删除页del.php

<?php
require("redis.php");
$uid = $_GET['id'];
$redis->del("user:".$uid);
$redis->lrem("uid",$uid);
header("location:list.php");


说明:删除hash表中的数据,和队列中的数据。

登录页login.php

<?php
require("redis.php");
$username = $_POST['username'];
$pass = $_POST['password'];
$id = $redis->get("username:".$username);
if(!empty($id)){
$password = $redis->hget("user:".$id,"password");
if(md5($pass) == $password){
$auth = md5(time().$username.rand());
$redis->set("auth:".$auth,$id);
setcookie("auth",$auth,time()+86400);
header("location:list.php");
}
}

?>
<form action="" method="post">
用户名:<input type="text" name="username" /><br />
密码:<input type="password" name="password" /><br />
<input type="submit" value="登陆" />
</form>


说明:获取数据并判断用户名是否存在,以及密码是否正确,如果正确,保存到cookie中。

登出页logout.php

<?php
setcookie("auth","",time()-1);
header("location:list.php");


说明:清除cookie中的数据。

添加粉丝页addfans.php

<?php
$id = $_GET['id'];
$uid = $_GET['uid'];
require("redis.php");
$redis->sadd("user:".$uid.":following",$id);
$redis->sadd("user:".$id.":followers",$uid);
header("location:list.php");


说明:一切都跟uid关联起来,这里的关注与粉丝用集合来存储。非常的合理。

小结:redis的使用,需要转变思维。它与传统的数据库还是有区别的,要能够巧妙的使用它的存储数据的几种类型。string、hash、list、set等等。来实现相关的功能。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: