一.redis.php
<?php //实例化 $redis = new Redis(); //连接服务器 $redis->connect("localhost"); //授权 $redis->auth("lamplijie"); //相关操作 $redis->set("name","lampbrother"); $data = $redis->key("*"); var_dump($data);
页面显示结果:
array(1) { [0]=> string(4) "name" }
二.简单回顾redis的四种数据类型
a.string:最简单的数据类型
set user:001:name lijie set user:001:age 20
b.hash:可以当做表,hash table,比string速度快
hset user:001 name lamp age 20 hset user:001 sex nan hset user:002 name lijie age 20 hgetall user:001
c.list:栈、队列
d.set:并集、交集、差集
e.zset:set升级版,多了一个顺序
三.小型的用户管理系统(用户的增删改查、分页、登陆退出、加关注)
redis.php
<?php //实例化 $redis = new Redis(); //连接服务器 $redis->connect("localhost"); //授权 $redis->auth("lamplijie");
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.php
<?php require("redis.php"); $username = $_POST['username']; $password = md5($_POST['password']); $age = $_POST['age']; echo $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.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> <?php } ?> </td> </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>
del.php
<?php require("redis.php"); $uid = $_GET['id']; $redis->del("user:".$uid); $redis->lrem("uid",$uid); header("localhost:list.php");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>
doedit.php
<?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); }
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>
logout.php
<?php setcookie("auth","",time()-1); header("location:list.php");
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");当然,采用sdiff user:1:following user:2:following语句,用户1可以向用户2推荐关注(即用户1的关注与用户2的关注的差集)。
相关推荐
PA195 NoSQL数据库-Redis运行一个实例# Create a network for a Redisdocker network create redisnet# Run a single instance that is automatically removed after being killeddocker run --rm --...
基于memcached协议和leveldb的持久数据库 基于redis协议和redis存储引擎的内存数据库,宕机后数据重放到内存 性能: 单机跑3个实例: 双核,Pentium(R) Dual-Core CPU E6600 @ 3.06GHz centos 5.6 erlang ...
07-NoSQL数据库之Redis数据库管理 李捷.doc 08-Smarty3视频教程.doc 09-HTML5.doc 10-百度开发平台.doc 11-兄弟连新版ThinkPHP视频教程.doc 12-PHP项目视频 高洛峰.doc 13-捷哥浅谈PHP.doc 14-兄弟连php视频教程CI...
您可以访问Redis实例/集群。 打开2个终端窗口 运行生产者 > cd redis-streams-101-node > node producer.js loop=1000 sleep=500 哪里: loop是程序发送的消息数(以lopp为单位) sleep的时间在每个消息柱之间...
适用 redis 非关系型数据库的图形化...RDM支持SSL / TLS加密,SSH隧道,基于SSH隧道的TLS(带有In-Transit加密的AWS ElastiCache)和云Redis实例,例如:Amazon ElastiCache,Microsoft Azure Redis Cache和Redis Labs
一个CSRF演示,窃取本地Redis数据,并加密本地网络上的所有Redis实例
Nsql缓存 适用于NoSQL数据库的高级缓存层 | | nsql-cache是用于NoSQL数据库客户端的高级缓存层。 它与供应商无关,并且当前具有以下数据库适配器: Google数据存储区的突出多亏了具有多个具有不同TTL的缓存存储...
Vedis嵌入式NoSQL数据库的快速Python绑定。 Vedis是一个模仿Redis的有趣,快速,嵌入式数据库。 。 产品特点 Vedis功能: 嵌入式零配置数据库 交易性(ACID) 单个文件或内存数据库 键/值存储 类似于标准命令的...
6.保证对应关系的简单性:一个mysql表对应一个 redis实例(redis单线程,多实例保证分流不阻塞),关联关系数据交给接口业务 数据:mysql->binlog->MQ->redis(不过期、关闭RDB、AOF保证读写性能) (nosql数据仅用...
RedisGraph-Redis的图形数据库模块 RedisGraph是第一个可查询的数据库,它使用表示图中的,并使用来查询图。 主要特点: 采用 可能具有属性的节点(顶点)和关系(边) 可以标记的节点 关系具有关系类型 表示为...
主要介绍了NoSQL和Redis简介及Redis在Windows下的安装和使用教程,本文同时讲解了python操作redis,并给出了操作实例,需要的朋友可以参考下
《Redis入门指南》是一本Redis的入门指导书籍,以通俗易懂的方式介绍了Redis基础与实践方面的知识,包括历史与特性、在开发和生产环境中部署运行...介绍了PHP、Ruby、Python和Node.js这4种语言的Redis客户端库的使用方法...
Spring Boot中除了对常用的关系型数据库提供了优秀的自动化支持之外,对于很多NoSQL数据库一样提供了自动化配置的支持。本篇文章主要介绍了Spring Boot中Redis的使用实例代码,有兴趣的开业了解一下。
KitDB是一个内嵌式持久型的高速NoSQL存储lib,以jar包方式嵌入到应用中。 KitDB提供了类似Redis的数据结构。如KV、List、Map、ZSET等。也提供了TTL(生存时间)、备份、ACID事物,多节点强一致性等功能。 KitDB完全...
本文实例讲述了Linux下redis的安装与使用。分享给大家供大家参考,具体如下: redis官网地址:http://www.redis.io 最新版本:3.2.6 1、下载、解压 wget http://download.redis.io/releases/redis-3.2.6.tar.gz 2...
Redis是一个NoSQL数据库,由于其数据类型的差异,所以要在MVC框架中实现CURD操作,比较繁锁。事实上在ThinkPHP框架中,只能实现简单的缓存应用。而不像MongoDB那样能够实现常见数据库的CURD操作。本文章将通过扩展的...
使用MERN Stack的Linkedin原型介绍使用Restful Web服务,React JS,NodeJS MySQL,Kafka,NoSQL数据库MongoDB,我们已经成功创建了LinkedIn的原型。 我们的应用程序包含两种主要类型的用户:申请人和招聘者。 登录后...
Redis 是目前 NoSQL 领域的当红炸子鸡,它象一把瑞士军刀,小巧、锋利、实用,特别适合解决一些使用传统关系数据库难以解决的问题。打算写一系列 Redis 使用模式的文章,深入总结介绍 Redis 常见的使用模式,以供...
Redis3.0 集群安装过程 1. 下载redis ...5. 修改 6个redis实例的配置文件 6. 安装集群需安装ruby运行环境 7. 编写脚本启动6个redis实例 8. 编辑启动集群脚本,启动集群 9. 测试集群环境 10. 关闭redis集群