redis+php微博,redis+php实现微博功能(一)

这篇博客介绍了如何利用Redis数据库实现微博用户的注册和登录功能。通过设置不同的Redis数据结构,如`userset`、`postset`等,存储用户信息和微博内容。注册时,检查用户名是否已存在,并存储用户数据;登录时,验证用户名和密码的正确性。代码简洁明了,主要涉及Redis的连接、数据存取操作。
摘要由CSDN通过智能技术生成

(一)、微博功能概况

微博用户账号注册

微博用户登录

微博发布

添加微博好友(粉丝)

微博推送

微博冷数据写入mysql数据库

(二)、redis数据结构设计

这节分享微博用户注册与登录:

我们完全采用redis作为数据库来实现注册于登录

先来看一下redis数据结构的设计:

注册用户表:user

set global:userid

set user:userid:1:username zhangshan

set user:userid:1:password 1212121212

set user:username:zhangshan:userid 1

发布微博表:post

set post:postid:3:time timestamp

set post:postid:3:userid 5

set post:postid:3:content 测试发布哈哈哈哈

incr global:postid

set post:postid:$postid

(三)、核心代码说明

注册代码:

include("function.php");

用户表单提交数据接收

$username = I(‘username‘);

$password = I(‘password‘);

$pwd = I(‘password2‘);

if(!$username || !$password || !$pwd){

exit(‘用户名密码不能够为空~‘);

}

if($password!=$pwd){

exit(‘两次密码输入不一致哦~‘);

}

//连接redis调用公用方法

$r = redis_connect();

//判断用户是否注册过

$info = $r->get("user:username:".$username.":userid");

if($info){

exit(‘该用户已经注册过‘);

}

//将用户数据存入redis中

$userid = $r->incr(‘global:userid‘);

$r->set("user:userid:".$userid.":username",$username);

$r->set("user:userid:".$userid.":password",$password);

$r->set("user:username:".$username.":userid",$userid);

header("location:home.php");

登录代码:

include("function.php");//如果用户已经登录调整到微博列表页面

if(isLogin()!=false){header("location:home.php");exit;

}$username = I(‘username‘);$password = I(‘password‘);if(!$username || !$password){exit(‘数据输入不完整‘);

}$r =redis_connect();$userid = $r->get("user:username:".$username.":userid");if(!$userid){exit(‘用户不存在‘);

}$password = $r->get("user:userid:".$userid."password:".$password);if(!password){exit(‘密码输入错误‘);

}/**设置cookie登录成功**/

setcookie(‘username‘,$username);setcookie(‘userid‘,$userid);header("location:home.php");

function文件代码:

/**/

functionredis_connect(){$redis = newRedis();$redis->connect(‘127.0.0.1‘,6379);return $redis;

}/**/

function I($post){if(empty($post)){return false;

}return trim($_POST[$post]);

}/**/

functionisLogin(){$username = $_COOKIE[‘username‘];$userid = $_COOKIE[‘userid‘];if(!$username || $userid){return false;

}return array(‘userid‘=>$userid,‘username‘=>$username);

}

说明:代码写的可能比较简单,这里只是阐述实现原理

原文:http://www.cnblogs.com/lisqiong/p/5568064.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值