目录

333

标签:

1. PHP 连接 Redis

访问 redis 官方网站的 client 栏目:http://www.redis.io/clients#php,可以获取 redis 的 php 扩展。

其中 phpredis 扩展比较稳定,功能也比较全,属于一个第三方扩展,但是已经被 PHP 官方授权,它的方法名和客户端下的方法名基本一致。github 地址:https://github.com/phpredis/phpredis,方法在这里也能查得到。

① 下载 phpredis 的源代码包,解压、配置、编译、安装;

② 编辑 php.ini,给 PHP 打上 redis 模块(extension=redis.so);

③ 写一个 phpinfo 的页面,访问,找到 redis 扩展:

技术分享

(这三步之前已经做过,参见:http://www.cnblogs.com/dee0912/p/4343032.html

④ 配置 Samba 服务器

(在一些中小型网络,或者企业的内部网中,利用Linux建立文件服务器是一个很好的解决方案。针对企业内部网中的绝大部分客户机采用Windows的情况,我们可以通过使用 Samba 来实现文件服务器功能。 )

打开光盘源:

技术分享

勾选“已连接”,选择 ISO 镜像文件,确定:

技术分享

挂载光盘镜像:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# mount /dev/cdrom /mnt/cdrom/
  2. mount: block device /dev/sr0 is write-protected, mounting read-only

yum 安装 samba(跳过有损的依赖包):

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# yum -y install samba* --skip-broken

安装完之后配置 samba 文件:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# vi /etc/samba/smb.conf

加几个虚拟目录:

  1. [web]
  2. path = /usr/local/apache2/htdocs
  3. browseable = yes
  4. writable = yes

browseable:可预览

技术分享

保存退出。

重启 smb 服务:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# service smb restart

如果提示:smb: 未被识别的服务,则说明没有安装完全,重新:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# yum install samba

重新执行重启 smb 服务:

技术分享

给 samba 服务其添加用户(apache):

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# smbpasswd -a apache
  2. New SMB password:
  3. Retype new SMB password:
  4. Failed to add entry for user apache.
  5. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]#

如果报错:Failed to add entry for user apache.

说明这是因为没有加相应的系统账号,所以会提示Failed to add entry for user的错误,只需增加相应的系统账号test就可以了(参见《增加samba用户提示Failed to add entry for user》):

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# groupadd apache -g 6000
  2. You have new mail in /var/spool/mail/root
  3. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# useradd apache -u 6000 -g 6000 -s /sbin/nologin -d /dev/null
  4. useradd:警告:此主目录已经存在。
  5. 不从 skel 目录里向其中复制任何文件。
  6. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# mkdir /home/apache
  7. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# chown 777 /home/apache
  8. You have new mail in /var/spool/mail/root
  9. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# smbpasswd -a apache
  10. New SMB password:
  11. Retype new SMB password:
  12. Mismatch - password unchanged.
  13. Unable to get new password.

[[email protected] ~]# smbpasswd -a apache
New SMB password:
Retype new SMB password:
Added user apache.
You have new mail in /var/spool/mail/root

用户名:apache,密码:123

⑤ 在 windows 下对 linux 进行映射:

技术分享

输入映射文件夹:

技术分享

输入用户名:apache,密码:123,确定:

技术分享

登陆之后:

技术分享

在目录中建立一个 redis 目录,提示没有权限:

技术分享

原因:apache 用户对本目录没有操作权限

解决方案:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# setfacl -m d:u:apache:rwx -R /usr/local/apache2/htdocs

查看 facl 权限:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# getfacl /usr/local/apache2/htdocs/
  2. getfacl: Removing leading ‘/‘ from absolute path names
  3. # file: usr/local/apache2/htdocs/
  4. # owner: apache
  5. # group: apache
  6. user::rwx
  7. user:apache:rwx
  8. group::r-x
  9. mask::rwx
  10. other::rwx
  11. default:user::rwx
  12. default:user:apache:rwx
  13. default:group::r-x
  14. default:mask::rwx
  15. default:other::r-x

如果还不行,则参照:《Samba服务中,不能创建文件夹和文本文件_解决办法》:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# vi /etc/selinux/config

技术分享

重启 Linux 服务器:

⑥ (在 test 目录下)重新创建 redis 目录,在 redis 目录中创建文件 redis.php,打开该文件,编辑:

  1. <?php
  2. //实例化 Redis 对象
  3. $redis = new Redis();
  4. //连接到 Redis 服务器
  5. $a = $redis->connect(‘localhost‘, 6379); //连接地址; 端口号; 连接时长,默认为0,不受限制
  6. var_dump($a);

启动 apache:

  1. /usr/local/apache2/bin/apachectl start

访问:192.168.254.100/redis/redis.php,输出:

表示连接 redis 服务已经成功。

此时登录客户端,输入 keys *:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# redis-cli -a phpdee
  2. 127.0.0.1:6379> keys *
  3. (empty list or set)

当前库中没有键;

同时可以在 redis.php 中使用 keys() 方法(要先授权,否则返回 bool(false) ):

  1. <?php
  2. //实例化 Redis 对象
  3. $redis = new Redis();
  4. //连接到 Redis 服务器
  5. $a = $redis->connect(‘localhost‘, 6379); //连接地址; 端口号; 连接时长,默认为0,不受限制
  6. //var_dump($a);
  7. $data = $redis->keys(‘*‘);
  8. var_dump($data);

访问:192.168.254.100/redis/redis.php,输出:

当前库中没有键。

此时在 redis.php 中使用 set() 方法创建一个键值对:

  1. <?php
  2. //实例化 Redis 对象
  3. $redis = new Redis();
  4. //连接到 Redis 服务器
  5. $a = $redis->connect(‘localhost‘, 6379); //连接地址; 端口号; 连接时长,默认为0,不受限制
  6. //var_dump($a);
  7. //授权
  8. $redis->auth(‘phpdee‘);
  9. //设置一个键值对
  10. $redis->set(‘name‘, dee‘);
  11. //获取 name 的值
  12. $name = $redis->get(‘name‘);
  13. var_dump($name);
  14. //获取库中所有的键
  15. $data = $redis->keys(‘*‘);
  16. var_dump($data);

访问:192.168.254.100/redis/redis.php,输出:

  1. string(3) "dee" array(1) { [0]=> string(4) "name" }

说明 set() 方法成功。

在 linux redis 客户端中再次查询库中的键:

  1. 127.0.0.1:6379> keys *
  2. 1) "name"
  3. 127.0.0.1:6379> get name
  4. "dee"

同样获取到了 key 为 name 的值。

【总结】操作步骤:实例化 redis 对象→连接 redis 服务器→授权→相关操作

相关操作:

使用 hash 类型存储用户信息

在 test 目录下新建 add.php(添加用户的界面,提交到 reg.php):

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>PHP+Redis信息管理系统</title>
  6. </head>
  7. <body>
  8. <form action="reg.php" method="post">
  9. <table align="left">
  10. <tr><td>用户名:</td><td><input type="text" name="username"></td></tr>
  11. <tr><td>密码:</td><td><input type="password" name="password" id=""></td></tr>
  12. <tr><td>年龄:</td><td><input type="text" name="age" id=""></td></tr>
  13. <tr><td><input type="submit" value="注册"></td><td><input type="reset" value="重填"></td></tr>
  14. </table>
  15. </form>
  16. </body>
  17. </html>

界面:

技术分享

reg.php(添加用户的操作):

  1. <?php
  2. require redis.php‘;
  3. $username = $_POST[‘username‘];
  4. $password = md5($_POST[‘password‘]);
  5. $age =$_POST[‘age‘];
  6. //uid 自加
  7. //当有 userid 这个键时,执行 incr时该键的值加1;不存在该键时,创建一个 userid,值为0,执行incr,值为1
  8. $uid = $redis->incr(‘userid‘);
  9. //向 hash 表中批量添加数据:hMset
  10. $redis->**hMset**(‘user:‘.$uid, array(‘uid‘=>$uid, name‘=>$username, password‘=>$password, age‘=>$age));
  11. //跳转
  12. header(‘location:list.php‘);

redis.php(实例化 redis 对象并连接 redis 服务器,同时授权):

  1. <?php
  2. //实例化 Redis 对象
  3. $redis = new Redis();
  4. //连接到 Redis 服务器
  5. $redis->**connect**(‘localhost‘, 6379); //连接地址; 端口号; 连接时长,默认为0,不受限制
  6. //授权
  7. $redis->**auth**(‘phpdee‘);

list.php(显示所有用户列表的界面,提供删除、编辑操作):

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>用户信息列表</title>
  6. </head>
  7. <body>
  8. <a href="add.php">返回注册页面</a>
  9. <?php
  10. require redis.php‘;
  11. for( $i = 1; $i <= $redis->**get**(‘userid‘); $i++ ){
  12. $data[] = $redis->**hgetall**(‘user:‘.$i);
  13. //过滤数组中的空元素
  14. $data = **array_filter**($data);
  15. }
  16. ?>
  17. <table border="1" cellspacing="0" cellpadding="5">
  18. <tr>
  19. <th>uid</th>
  20. <th>name</th>
  21. <th>age</th>
  22. <th>操作</th>
  23. </tr>
  24. <?php foreach($data as $v){ ?>
  25. <tr>
  26. <td><?php echo $v[‘uid‘]?></td>
  27. <td><?php echo $v[‘name‘]?></td>
  28. <td><?php echo $v[‘age‘]?></td>
  29. <td><a href="del.php?uid=<?php echo $v[‘uid‘];?>">删除</a> | <a href="mod.php?uid=<?php echo $v[‘uid‘];?>">编辑</a></td>
  30. </tr>
  31. <?php } ?>
  32. </table>
  33. </body>
  34. </html>

http://192.168.254.100/redis/add.php 中输入信息,注册(例如姓名:dee,密码:123,年龄:25);

注册完之后进入 redis 客户端:

  1. 127.0.0.1:6379> keys *
  2. 1) "userid"
  3. 2) "user:1"
  4. 127.0.0.1:6379> get userid
  5. "1"
  6. 127.0.0.1:6379> hgetall user:1
  7. 1) "uid"
  8. 2) "1"
  9. 3) "name"
  10. 4) "dee"
  11. 5) "password"
  12. 6) "202cb962ac59075b964b07152d234b70"
  13. 7) "age"
  14. 8) "25"

多次测试之后访问 http://192.168.254.100/redis/list.php:

技术分享

del.php(删除用户信息的操作):

  1. <?php
  2. require redis.php‘;
  3. $uid = $_GET[‘uid‘];
  4. $redis->**del**(‘user:‘.$uid);
  5. header(‘location:list.php‘);

mod.php(编辑用户信息的界面,和 add.php 相似):

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>编辑用户</title>
  6. </head>
  7. <body>
  8. <?php
  9. require redis.php‘;
  10. $uid = $_GET[‘uid‘];
  11. $data = $redis->hgetall(‘user:‘.$uid);
  12. ?>
  13. <form action="doEdit.php" method="post">
  14. <table align="left">
  15. <tr><td>用户名:</td><td><input type="text" name="username" value="<?php echo $data[‘name‘];?>"></td></tr>
  16. <tr><td>年龄:</td><td><input type="text" name="age" value="<?php echo $data[‘age‘];?>"></td></tr>
  17. <tr><td><input type="submit" value="修改"></td><td><input type="hidden" name="uid" value="<?php echo $data[‘uid‘];?>"></td></tr>
  18. </table>
  19. </form>
  20. </body>
  21. </html>

技术分享

doEdit.php(编辑用户的操作):

  1. <?php
  2. require redis.php‘;
  3. $uid = $_POST[‘uid‘];
  4. $name = $_POST[‘username‘];
  5. $age = $_POST[‘age‘];
  6. //执行批量更改
  7. $res = $redis->hmset(‘user:‘.$uid, array(‘name‘=>$name, age‘=>$age));
  8. //跳转
  9. if($res){
  10. header(‘location:list.php‘);
  11. }

【附】查看 redis 服务是否启动:

  1. [[[email protected]](http://www.mamicode.com/cdn-cgi/l/email-protection) ~]# netstat -tunpl | grep 6379
  2. tcp 0 0 0.0.0.0:6379 0.0.0.0:* LISTEN 2061/redis-server *
  3. tcp 0 0 :::6379 :::* LISTEN 2061/redis-server *

Redis 笔记与总结7 PHP + Redis 信息管理系统(用户信息的增删改查)

标签:

原文地址:http://www.cnblogs.com/dee0912/p/4605750.html
timg