分类目录归档:PHP开发

记录PHP开发点点滴滴,PHP博客,PHP博客系统,PHP开源电子商务系统,zencart,magento,joomla

laravel5.0在php7.0下异常解决

FatalErrorException in Handler.php line 25:

Uncaught TypeError: Argument 1 passed to App\Exceptions\Handler::report() must be an instance of Exception, instance of Error given, called in vendor\laravel\framework\src\Illuminate\Foundation\Bootstrap\HandleExceptions.php on line 73 and defined in app\Exceptions\Handler.php:25

Stack trace:
#0 vendor\laravel\framework\src\Illuminate\Foundation\Bootstrap\HandleExceptions.php(73): App\Exceptions\Handler->report(Object(Error))
#1 [internal function]: Illuminate\Foundation\Bootstrap\HandleExceptions->handleException(Object(Error))
#2 {main}
thrown

 

laravel5升级php7.0后报以上错误,

原因:PHP7的改动中,影响比较大的,包括异常处理。PHP7实现了一个全局的throwable接口,原来的Exception和部分Error都实现了这个接口(interface), 以接口的方式定义了异常的继承结构。于是,PHP7中更多的Error变为可捕获的Exception返回给开发者,如果不进行捕获则为Error,如果捕获就变为一个可在程序内处理的Exception。这些可被捕获的Error通常都是不会对程序造成致命伤害的Error,例如函数不存

 

解决办法:

vendor\laravel\framework\src\Illuminate\Foundation\Bootstrap\HandleExceptions.php

引入

use Symfony\Component\Debug\Exception\FatalErrorException;

然后在handleException使用大概73行

if (! $e instanceof Exception) {
    $e = new FatalThrowableError($e);
}

加入后如下

public function handleException($e)
{
    if (! $e instanceof Exception) {
        $e = new FatalThrowableError($e);
    }

    $this->getExceptionHandler()->report($e);

    if ($this->app->runningInConsole()) {
        $this->renderForConsole($e);
    } else {
        $this->renderHttpResponse($e);
    }
}

php图像处理,php图像裁剪

PHP图片处理库Grafika
Grafika是一个PHP图像处理库,是基于Imagick和GD,可以用于改变图片大小,剪裁,比较,添加水印等等功能。还有感知哈希,高级图像过滤,绘制贝塞尔曲线等功能,可谓非常强大。

缩略图的速度非常快,质量非常高
支持智能剪裁
很好的支持GIF图片
5种缩略图模式
图像对比功能
图像高级过滤功能
图像混合
其他图像处理库支持的API基本都支持

安装下载

1、直接下载:

Grafika的官网Github地址

2、composer:

composer require kosinix/grafika:dev-master –prefer-dist

环境需求

PHP >= 5.3,当然官方推荐php7
GD库 >= 2.0版本
Imagick最好(不强求)>=3.3.0 , ImageMagick >= 6.5.3

 

以下记录几篇国内翻译的比较好的文档地址

https://segmentfault.com/a/1190000007415756

 

官网下载地址

https://kosinix.github.io/grafika/index.html

PHP内置ZipArchive添加文件至压缩包zip

PHP内置ZipArchive添加文件至压缩包,PHP5.6 使用自带ZipArchive实现文件夹以及文件的压缩
$zip = new ZipArchive();
$zipfile = '1.zip';
$addfile = 'test\\';
if (file_exists($zipfile)) {
unlink($zipfile);
}
if(!file_exists($addfile)){
echo 'no add file';
}
$zip->open($zipfile, ZipArchive::CREATE);
$allFile = getAllFile($addfile);
foreach ($allFile as $allfiles) {
$zip->addFile($allfiles);
}
$zip->close();

function getAllFile($file, $fileRes = [])
{
if (!file_exists($file)) {
return [];
}
$dir = opendir($file);
while (false !== ($path = readdir($dir))) {
if ($path != '.' && $path != '..') {
if (is_dir($file . $path)) {
$fileRes = getAllFile($file . $path . '\\', $fileRes);
} else {
$fileRes[] = $file . $path;
}
}
}
return $fileRes;

}

实现添加文件夹内套文件夹及文件

Mysql主从服务配置

Mysql主从服务配置

操作实例两台服务器
Win7 mysql5.5.*
VM虚拟机 Centos7 lnmp2 mysql 5.5.*

1.主服务器配置

修改主服务器mysql配置文件
windows下mysql配置文件名称my.ini
添加或者修改
log-bin=mysql-bin
server-id=1
查看server-id可以执行sql语句
show variables like ‘server_id’;
显示结果
+—————+——-+
| Variable_name | Value |
+—————+——-+
| server_id     | 1     |
+—————+——-+

主服务器上执行sql语句创建slave帐户并授权slave:

GRANT REPLICATION SLAVE ON *.* to ‘slave’@’%’ identified by ‘123’;
这里可以指定从服务器的IP地址,先用%允许所有远程访问

登录主服务器的mysql查看master状态

mysql> show master status;
+——————+———-+————–+——————+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———-+————–+——————+
| mysql-bin.000004 |      107 |              |                  |
+——————+———-+————–+——————+
1 row in set (0.00 sec)

记录当前File,Position的值

重启主服务器mysql服务

2.从服务器配置

修改mysql配置文件,Lnmp的mysql配置文件位于/etc/my.cnf

添加或者修改server-id,不能于主服务器的server-id冲突

server-id=2

重启从服务器mysql服务

登录终端执行sql语句
1.停止slave:
stop slave;
2.执行master语句:
change master to master_host=’主服务器IP地址’,master_port=’3306′,master_user=’slave’,master_password=’123′,
master_log_file=’mysql-bin.000001′,master_log_pos=107;
3.启动slave
start slave

4.查看slave状态
show slave status \G

*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.1.168
Master_User: slave
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000004
Read_Master_Log_Pos: 107
Relay_Log_File: localhost-relay-bin.000015
Relay_Log_Pos: 253
Relay_Master_Log_File: mysql-bin.000004
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

Slave_IO_Running,Slave_SQL_Running如果任何一个No都是失败的,具体错误信息可以查看mysql错误日志

这里完成了简单mysql主从配置,可以在主服务器创建数据库表看看效果,
搭配读写分离的PHP框架开始装逼飞吧

Mysql开启慢查询日志

Mysql开启慢查询日志,查看MYSQL服务器的慢查询状态是否开启.执行如下命令:

mysql> show variables  like ‘%slow%’;

+———————+————————————————-+
| Variable_name       | Value                                           |
+———————+————————————————-+
| log_slow_queries    | OFF                                             |
| slow_launch_time    | 2                                               |
| slow_query_log      | OFF                                             |
| slow_query_log_file | D:\MySQL\data\I9GG-20160602NR-slow.log |
+———————+————————————————-+

看到当前log_slow_queries状态为OFF

开启慢查询:

找到mysql的配置文件 windows下my.ini linux下my.cnf

在[mysqld]中添加如下信息:

[mysqld]

log-slow-queries=”D:\MySQL\data\I9GG-20160602NR-slow.log ”

#代表MYSQL慢查询的日志, 此目录文件一定要有写权限;
long_query_time = 4

#最长执行时间.
log-queries-not-using-indexes

#没有使用到索引的查询也将被记录在日志中

配置好以后重新启动MYSQL服务
mysql> show variables  like ‘%slow%’;

+———————+————————————+
| Variable_name       | Value                              |
+———————+————————————+
| log_slow_queries    | ON                                 |
| slow_launch_time    | 2                                  |
| slow_query_log      | ON                                 |
| slow_query_log_file | D:\tmp\log\mysql_slow.log |
+———————+————————————+
4 rows in set (0.01 sec)

Ecshop几个Xss漏洞修复

Ecshop几个相关Xss漏洞
Ecshop pages.lbi.php Xss漏洞,search.php注入漏洞,Ecshop version XSS漏洞

1.Ecshop pages.lbi.php Xss漏洞

先来分析这个漏洞的原因:

直接访问temp/compiled/pages.lbi.php时,浏览源文件,会发现如下代码:

<form action=”temp/compiled/pages.lbi.php” method=”get”>

显然这个form是不完全的。当构造这样的url访问时,会造成在客户端执行代码:

temp/compiled/pages.lbi.php/”</form><sCripT>alert(/cfreer/)</scRipt>

很显然,这个漏洞的原理就是闭合了这个form再在客户端执行javascript.

然后分析出现不闭合form的原因,打开page.lbi.php文件,可以看到如下代码

<form action=”<?php echo $_SERVER[‘PHP_SELF’]; ?>” method=”get”> <?php if ($this->_var[‘pager’][‘styleid’] == 0): ?>

这里执行$this的时候就出现错误了,,因为没有进行template的初始化。

既然找到原因了,下面给出解决办法:

打开page.lbi文件,在第二行插入如下代码:

<?php if (!defined(‘IN_ECS’)) { die(‘Hacking attempt’); } ?>

2.search.php注入漏洞

search.php
大概300 源
if (is_not_null($val) )
修改为
if (is_not_null($val) && is_numeric($key))
就可以了

3.Ecshop version XSS漏洞

打开/admin/receive.php文件中,搜索如下代码:

$version=$_GET[‘version’];

修改为如下代码:

$version=htmlspecialchars($_GET[‘version’]);

PhpExcel中文帮助手册PhpExcel使用方法

PhpExcel中文帮助手册PhpExcel使用方法,总结一些常用的方法,方便大家使用

 

引入方法
下面是总结的几个使用方法
include 'PHPExcel.php';
include 'PHPExcel/Writer/Excel2007.php';
//或者include 'PHPExcel/Writer/Excel5.php'; 用于输出.xls的

创建一个excel

$objPHPExcel = new PHPExcel();

保存excel—2007格式

$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);
//或者$objWriter = new PHPExcel_Writer_Excel5($objPHPExcel); 非2007格式
$objWriter->save("xxx.xlsx");

直接输出到浏览器

$objWriter = new PHPExcel_Writer_Excel5($objPHPExcel);
header("Pragma: public");
header("Expires: 0″);
header("Cache-Control:must-revalidate, post-check=0, pre-check=0″);
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");;
header('Content-Disposition:attachment;filename="resume.xls"');
header("Content-Transfer-Encoding:binary");
$objWriter->save('php://output');

——————————————————————————————————————–
设置excel的属性:
创建人

$objPHPExcel->getProperties()->setCreator("Maarten Balliauw");

最后修改人

$objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");

标题

$objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");

题目

$objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");

描述

$objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");
关键字

$objPHPExcel->getProperties()->setKeywords("office 2007 openxml php");

种类

$objPHPExcel->getProperties()->setCategory("Test result file");

——————————————————————————————————————–
设置当前的sheet

$objPHPExcel->setActiveSheetIndex(0);

设置sheet的name

$objPHPExcel->getActiveSheet()->setTitle('Simple');

设置单元格的值

$objPHPExcel->getActiveSheet()->setCellValue('A1', 'String');
$objPHPExcel->getActiveSheet()->setCellValue('A2', 12);
$objPHPExcel->getActiveSheet()->setCellValue('A3', true);
$objPHPExcel->getActiveSheet()->setCellValue('C5', '=SUM(C2:C4)');
$objPHPExcel->getActiveSheet()->setCellValue('B8', '=MIN(B2:C5)');

合并单元格

$objPHPExcel->getActiveSheet()->mergeCells('A18:E22');//注意区间就行比如合并A1 B1 C1 D1写法A1:D1

分离单元格

$objPHPExcel->getActiveSheet()->unmergeCells('A28:B28');

保护cell

$objPHPExcel->getActiveSheet()->getProtection()->setSheet(true); // Needs to be set to true in order to enable any worksheet protection!
$objPHPExcel->getActiveSheet()->protectCells('A3:E13', 'PHPExcel');

设置格式

// Set cell number formats
echo date('H:i:s') . " Set cell number formats\n";
$objPHPExcel->getActiveSheet()->getStyle('E4')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_CURRENCY_EUR_SIMPLE);
$objPHPExcel->getActiveSheet()->duplicateStyle( $objPHPExcel->getActiveSheet()->getStyle('E4'), 'E5:E13' );

设置宽width

// Set column widths
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setAutoSize(true);
$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(12);

设置font

$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setName('Candara');
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setSize(20);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE);
$objPHPExcel->getActiveSheet()->getStyle('E1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE);
$objPHPExcel->getActiveSheet()->getStyle('D13')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('E13')->getFont()->setBold(true);

设置align

$objPHPExcel->getActiveSheet()->getStyle('D11')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('D12')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('D13')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY);

垂直居中

$objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);

设置column的border

$objPHPExcel->getActiveSheet()->getStyle('A4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('B4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('C4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('D4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('E4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);

设置border的color

$objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getLeft()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getRight()->getColor()->setARGB('FF993300');

设置填充颜色

$objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
$objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->getStartColor()->setARGB('FF808080');
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->getStartColor()->setARGB('FF808080');

加图片

$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName('Logo');
$objDrawing->setDescription('Logo');
$objDrawing->setPath('./images/officelogo.jpg');
$objDrawing->setHeight(36);
$objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName('Paid');
$objDrawing->setDescription('Paid');
$objDrawing->setPath('./images/paid.png');
$objDrawing->setCoordinates('B15');
$objDrawing->setOffsetX(110);
$objDrawing->setRotation(25);
$objDrawing->getShadow()->setVisible(true);
$objDrawing->getShadow()->setDirection(45);
$objDrawing->setWorksheet($objPHPExcel->getActiveSheet());

处理中文输出问题
需要将字符串转化为UTF-8编码,才能正常输出,否则中文字符将输出为空白,如下处理:

$str = iconv('gb2312', 'utf-8', $str);

或者你可以写一个函数专门处理中文字符串:

function convertUTF8($str)
{
if(empty($str)) return '';
return iconv('gb2312', 'utf-8', $str);
}

从数据库读取数据如:

$db = new Mysql($dbconfig);
$sql = "SELECT * FROM 表名";
$row = $db->GetAll($sql); // $row 为二维数组
$count = count($row);
for ($i = 2; $i <= $count+1; $i++) { $objPHPExcel->getActiveSheet()->setCellValue('A' . $i, convertUTF8($row[$i-2][1]));
$objPHPExcel->getActiveSheet()->setCellValue('B' . $i, convertUTF8($row[$i-2][2]));
$objPHPExcel->getActiveSheet()->setCellValue('C' . $i, convertUTF8($row[$i-2][3]));
$objPHPExcel->getActiveSheet()->setCellValue('D' . $i, convertUTF8($row[$i-2][4]));
$objPHPExcel->getActiveSheet()->setCellValue('E' . $i, convertUTF8(date("Y-m-d", $row[$i-2][5])));
$objPHPExcel->getActiveSheet()->setCellValue('F' . $i, convertUTF8($row[$i-2][6]));
$objPHPExcel->getActiveSheet()->setCellValue('G' . $i, convertUTF8($row[$i-2][7]));
$objPHPExcel->getActiveSheet()->setCellValue('H' . $i, convertUTF8($row[$i-2][8]));
}

在默认sheet后,创建一个worksheet

echo date('H:i:s') . " Create new Worksheet object\n";
$objPHPExcel->createSheet();
$objWriter = PHPExcel_IOFactory::createWriter($objExcel, 'Excel5');
$objWriter-save('php://output');

PHP Redis文档函数

PHP-redis文档函数

redis官方提供的命令使用技巧:下载地址如下:https://github.com/owlient/phpredis

 

Redis::__construct构造函数
$redis = new Redis();

connect, open 链接redis服务
参数
host: string,服务地址
port
: int,端口号
timeout
: float,链接时长 (可选, 默认为 0 ,不限链接时间)
注: 在redis.conf中也有时间,默认为300

pconnect, popen 不会主动关闭的链接
参考上面

setOption 设置redis模式

getOption 查看redis设置的模式

ping 查看连接状态

get
得到某个key的值(string值)
如果该key不存在,return false

set
写入key 和 value(string值)
如果写入成功,return ture

setex 带生存时间的写入值
$redis->setex(‘key’, 3600, ‘value’); // sets key → value, with 1h TTL.

setnx
判断是否重复的,写入值
$redis->setnx(‘key’, ‘value’);
$redis->setnx(‘key’, ‘value’);

delete  删除指定key的值
返回已经删除key的个数(长整数)
$redis->delete(‘key1’, ‘key2’);
$redis->delete(array(‘key3’, ‘key4’, ‘key5’));

ttl
得到一个key的生存时间

persist
移除生存时间到期的key
如果key到期 true 如果不到期 false

mset (redis版本1.1以上才可以用)
同时给多个key赋值
$redis->mset(array(‘key0’ => ‘value0’, ‘key1’ => ‘value1’));

multi, exec, discard
进入或者退出事务模式
参数可选Redis::MULTI或Redis::PIPELINE. 默认是 Redis::MULTI
Redis::MULTI:将多个操作当成一个事务执行
Redis::PIPELINE:让(多条)执行命令简单的,更加快速的发送给服务器,但是没有任何原子性的保证
discard:删除一个事务
返回值
multi(),返回一个redis对象,并进入multi-mode模式,一旦进入multi-mode模式,以后调用的所有方法都会返回相同的对象,只到exec()方法被调用。

watch, unwatch (代码测试后,不能达到所说的效果)
监测一个key的值是否被其它的程序更改。如果这个key在watch 和 exec (方法)间被修改,这个 MULTI/EXEC 事务的执行将失败(return false)
unwatch  取消被这个程序监测的所有key
参数,一对key的列表
$redis->watch(‘x’);

$ret = $redis->multi() ->incr(‘x’) ->exec();


subscribe
*
方法回调。注意,该方法可能在未来里发生改变

publish *
发表内容到某一个通道。注意,该方法可能在未来里发生改变

exists
判断key是否存在。存在 true 不在 false

incr, incrBy
key中的值进行自增1,如果填写了第二个参数,者自增第二个参数所填的值
$redis->incr(‘key1’);
$redis->incrBy(‘key1’, 10);

decr, decrBy
做减法,使用方法同incr

getMultiple
传参
由key组成的数组
返回参数
如果key存在返回value,不存在返回false
$redis->set(‘key1’, ‘value1’); $redis->set(‘key2’, ‘value2’); $redis->set(‘key3’, ‘value3’); $redis->getMultiple(array(‘key1’, ‘key2’, ‘key3’));
$redis->lRem(‘key1’, ‘A’, 2);
$redis->lRange(‘key1’, 0, -1);

list
相关操作
lPush
$redis->lPush(key, value);
在名称为key的list左边(头)添加一个值为value的 元素

rPush
$redis->rPush(key, value);
在名称为key的list右边(尾)添加一个值为value的 元素

lPushx/rPushx
$redis->lPushx(key, value);
在名称为key的list左边(头)/右边(尾)添加一个值为value的元素,如果value已经存在,则不添加

lPop/rPop
$redis->lPop(‘key’);
输出名称为key的list左(头)起/右(尾)起的第一个元素,删除该元素

blPop/brPop
$redis->blPop(‘key1’, ‘key2’, 10);
lpop命令的block版本。即当timeout为0时,若遇到名称为key i的list不存在或该list为空,则命令结束。如果timeout>0,则遇到上述情况时,等待timeout秒,如果问题没有解决,则对keyi+1开始的list执行pop操作

lSize
$redis->lSize(‘key’);
返回名称为key的list有多少个元素

lIndex, lGet
$redis->lGet(‘key’, 0);
返回名称为key的list中index位置的元素

lSet
$redis->lSet(‘key’, 0, ‘X’);
给名称为key的list中index位置的元素赋值为value

lRange, lGetRange
$redis->lRange(‘key1’, 0, -1);
返回名称为key的list中start至end之间的元素(end为 -1 ,返回所有)

lTrim, listTrim
$redis->lTrim(‘key’, start, end);
截取名称为key的list,保留start至end之间的元素

lRem, lRemove
$redis->lRem(‘key’, ‘A’, 2);
删除count个名称为key的list中值为value的元素。count为0,删除所有值为value的元素,count>0从头至尾删除count个值为value的元素,count<0从尾到头删除|count|个值为value的元素

lInsert
在名称为为key的list中,找到值为pivot 的value,并根据参数Redis::BEFORE | Redis::AFTER,来确定,newvalue 是放在 pivot 的前面,或者后面。如果key不存在,不会插入,如果 pivot不存在,return -1
$redis->delete(‘key1’); $redis->lInsert(‘key1’, Redis::AFTER, ‘A’, ‘X’); $redis->lPush(‘key1’, ‘A’); $redis->lPush(‘key1’, ‘B’); $redis->lPush(‘key1’, ‘C’); $redis->lInsert(‘key1’, Redis::BEFORE, ‘C’, ‘X’);
$redis->lRange(‘key1’, 0, -1);
$redis->lInsert(‘key1’, Redis::AFTER, ‘C’, ‘Y’);
$redis->lRange(‘key1’, 0, -1);
$redis->lInsert(‘key1’, Redis::AFTER, ‘W’, ‘value’);

rpoplpush
返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部
$redis->delete(‘x’, ‘y’);
$redis->lPush(‘x’, ‘abc’); $redis->lPush(‘x’, ‘def’); $redis->lPush(‘y’, ‘123’); $redis->lPush(‘y’, ‘456’); // move the last of x to the front of y. var_dump($redis->rpoplpush(‘x’, ‘y’));
var_dump($redis->lRange(‘x’, 0, -1));
var_dump($redis->lRange(‘y’, 0, -1));

string(3) “abc”
array(1) { [0]=> string(3) “def” }
array(3) { [0]=> string(3) “abc” [1]=> string(3) “456” [2]=> string(3) “123” }

SET操作相关
sAdd
向名称为key的set中添加元素value,如果value存在,不写入,return false
$redis->sAdd(key , value);

sRem, sRemove
删除名称为key的set中的元素value
$redis->sAdd(‘key1’ , ‘set1’);
$redis->sAdd(‘key1’ , ‘set2’);
$redis->sAdd(‘key1’ , ‘set3’);
$redis->sRem(‘key1’, ‘set2’);

sMove
将value元素从名称为srckey的集合移到名称为dstkey的集合
$redis->sMove(seckey, dstkey, value);

sIsMember, sContains
名称为key的集合中查找是否有value元素,有ture 没有 false
$redis->sIsMember(key, value);

sCard, sSize
返回名称为key的set的元素个数

sPop
随机返回并删除名称为key的set中一个元素

sRandMember
随机返回名称为key的set中一个元素,不删除

sInter
求交集

sInterStore
求交集并将交集保存到output的集合
$redis->sInterStore(‘output’, ‘key1’, ‘key2’, ‘key3’)

sUnion
求并集
$redis->sUnion(‘s0’, ‘s1’, ‘s2’);
s0,s1,s2 同时求并集

sUnionStore
求并集并将并集保存到output的集合
$redis->sUnionStore(‘output’, ‘key1’, ‘key2’, ‘key3’);

sDiff
求差集

sDiffStore
求差集并将差集保存到output的集合

sMembers, sGetMembers
返回名称为key的set的所有元素

sort
排序,分页等
参数
‘by’ => ‘some_pattern_*’,
‘limit’ => array(0, 1),
‘get’ => ‘some_other_pattern_*’ or an array of patterns,
‘sort’ => ‘asc’ or ‘desc’,
‘alpha’ => TRUE,
‘store’ => ‘external-key’
例子
$redis->delete(‘s’); $redis->sadd(‘s’, 5); $redis->sadd(‘s’, 4); $redis->sadd(‘s’, 2); $redis->sadd(‘s’, 1); $redis->sadd(‘s’, 3);
var_dump($redis->sort(‘s’)); // 1,2,3,4,5
var_dump($redis->sort(‘s’, array(‘sort’ => ‘desc’))); // 5,4,3,2,1
var_dump($redis->sort(‘s’, array(‘sort’ => ‘desc’, ‘store’ => ‘out’))); // (int)5

string命令
getSet
返回原来key中的值,并将value写入key
$redis->set(‘x’, ’42’);
$exValue = $redis->getSet(‘x’, ‘lol’); // return ’42’, replaces x by ‘lol’
$newValue = $redis->get(‘x’)’ // return ‘lol’

append
string,名称为key的string的值在后面加上value
$redis->set(‘key’, ‘value1’);
$redis->append(‘key’, ‘value2’);
$redis->get(‘key’);

getRange (方法不存在)
返回名称为key的string中start至end之间的字符
$redis->set(‘key’, ‘string value’);
$redis->getRange(‘key’, 0, 5);
$redis->getRange(‘key’, -5, -1);

setRange (方法不存在)
改变key的string中start至end之间的字符为value
$redis->set(‘key’, ‘Hello world’);
$redis->setRange(‘key’, 6, “redis”);
$redis->get(‘key’);

strlen
得到key的string的长度
$redis->strlen(‘key’);

getBit/setBit
返回2进制信息

zsetsorted set)操作相关
zAdd(key, score, member)
:向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
$redis->zAdd(‘key’, 1, ‘val1’);
$redis->zAdd(‘key’, 0, ‘val0’);
$redis->zAdd(‘key’, 5, ‘val5’);
$redis->zRange(‘key’, 0, -1); // array(val0, val1, val5)

zRange(key, start, end,
withscores):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
$redis->zAdd(‘key1’, 0, ‘val0’);
$redis->zAdd(‘key1’, 2, ‘val2’);
$redis->zAdd(‘key1’, 10, ‘val10’);
$redis->zRange(‘key1’, 0, -1); // with scores $redis->zRange(‘key1’, 0, -1, true);

zDelete, zRem

zRem(key, member) :删除名称为key的zset中的元素member
$redis->zAdd(‘key’, 0, ‘val0’);
$redis->zAdd(‘key’, 2, ‘val2’);
$redis->zAdd(‘key’, 10, ‘val10’);
$redis->zDelete(‘key’, ‘val2’);
$redis->zRange(‘key’, 0, -1);

zRevRange(key, start, end,withscores):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素.withscores: 是否输出socre的值,默认false,不输出
$redis->zAdd(‘key’, 0, ‘val0’);
$redis->zAdd(‘key’, 2, ‘val2’);
$redis->zAdd(‘key’, 10, ‘val10’);
$redis->zRevRange(‘key’, 0, -1); // with scores $redis->zRevRange(‘key’, 0, -1, true);

zRangeByScore, zRevRangeByScore
$redis->zRangeByScore(key, star, end, array(withscores, limit ));
返回名称为key的zset中score >= star且score <= end的所有元素

zCount
$redis->zCount(key, star, end);
返回名称为key的zset中score >= star且score <= end的所有元素的个数

zRemRangeByScore, zDeleteRangeByScore
$redis->zRemRangeByScore(‘key’, star, end);
删除名称为key的zset中score >= star且score <= end的所有元素,返回删除个数

zSize, zCard
返回名称为key的zset的所有元素的个数

zScore
$redis->zScore(key, val2);
返回名称为key的zset中元素val2的score

zRank, zRevRank
$redis->zRevRank(key, val);
返回名称为key的zset(元素已按score从小到大排序)中val元素的rank(即index,从0开始),若没有val元素,返回“null”。zRevRank 是从大到小排序

zIncrBy
$redis->zIncrBy(‘key’, increment, ‘member’);
如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment

zUnion/zInter
参数
keyOutput
arrayZSetKeys
arrayWeights
aggregateFunction
Either “SUM”, “MIN”, or “MAX”: defines the behaviour to use on duplicate entries during the zUnion.
对N个zset求并集和交集,并将最后的集合保存在dstkeyN中。对于集合中每一个元素的score,在进行AGGREGATE运算前,都要乘以对于的WEIGHT参数。如果没有提供WEIGHT,默认为1。默认的AGGREGATE是SUM,即结果集合中元素的score是所有集合对应元素进行SUM运算的值,而MIN和MAX是指,结果集合中元素的score是所有集合对应元素中最小值和最大值。

Hash操作
hSet

$redis->hSet(‘h’, ‘key1’, ‘hello’);
向名称为h的hash中添加元素key1—>hello

hGet
$redis->hGet(‘h’, ‘key1’);
返回名称为h的hash中key1对应的value(hello)

hLen
$redis->hLen(‘h’);
返回名称为h的hash中元素个数

hDel
$redis->hDel(‘h’, ‘key1’);
删除名称为h的hash中键为key1的域

hKeys
$redis->hKeys(‘h’);
返回名称为key的hash中所有键

hVals
$redis->hVals(‘h’)
返回名称为h的hash中所有键对应的value

hGetAll
$redis->hGetAll(‘h’);
返回名称为h的hash中所有的键(field)及其对应的value

hExists
$redis->hExists(‘h’, ‘a’);
名称为h的hash中是否存在键名字为a的域

hIncrBy
$redis->hIncrBy(‘h’, ‘x’, 2);
将名称为h的hash中x的value增加2

hMset
$redis->hMset(‘user:1’, array(‘name’ => ‘Joe’, ‘salary’ => 2000));
向名称为key的hash中批量添加元素

hMGet
$redis->hmGet(‘h’, array(‘field1’, ‘field2’));
返回名称为h的hash中field1,field2对应的value

redis 操作相关
flushDB
清空当前数据库

flushAll

清空所有数据库

randomKey
随机返回key空间的一个key
$key = $redis->randomKey();

select
选择一个数据库
move
转移一个key到另外一个数据库
$redis->select(0); // switch to DB 0
$redis->set(‘x’, ’42’); // write 42 to x
$redis->move(‘x’, 1); // move to DB 1
$redis->select(1); // switch to DB 1
$redis->get(‘x’); // will return 42

rename, renameKey
给key重命名
$redis->set(‘x’, ’42’);
$redis->rename(‘x’, ‘y’);
$redis->get(‘y’); // → 42
$redis->get(‘x’); // → `FALSE`

renameNx
与remane类似,但是,如果重新命名的名字已经存在,不会替换成功

setTimeout, expire
设定一个key的活动时间(s)
$redis->setTimeout(‘x’, 3);

expireAt
key存活到一个unix时间戳时间
$redis->expireAt(‘x’, time() + 3);

keys, getKeys
返回满足给定pattern的所有key
$keyWithUserPrefix = $redis->keys(‘user*’);

dbSize
查看现在数据库有多少key
$count = $redis->dbSize();

auth
密码认证
$redis->auth(‘foobared’);

bgrewriteaof
使用aof来进行数据库持久化
$redis->bgrewriteaof();

slaveof
选择从服务器
$redis->slaveof(‘10.0.1.7’, 6379);

save
将数据同步保存到磁盘

bgsave
将数据异步保存到磁盘

lastSave
返回上次成功将数据保存到磁盘的Unix时戳

info

返回redis的版本信息等详情

Redis在Windows下安装及redis在PHP中使用

Redis在Windows下安装及redis在PHP中使用

1、redis简介
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。

2、Windows下安装redis
下载地址https://github.com/dmajkic/redis/downloads。

这里我下载redis-2.4.5-win32-win64.zip,解压后拷贝32bit到D:\redis\32bit

打开cmd窗口,使用cd命令切换到指定目录(D:\redis\32bit)运行

redis-server.exe redis.conf
如下图
redis-1

Redis服务端已经安装成功。

再新打开一个cmd窗口,使用cd命令切换到指定目录(D:\redis\32bit)运行

redis-cli.exe -h 127.0.0.1 -p 6379
如下图
redis-2
Redis客户端连接成功
注释:其中服务端IP 127.0.0.1 端口6379

在客户端连接的cmd中输入内容进行测试
set test ‘hello man’
get test
如下图所示
redis-3

 

3、这里讲一下PHP中使用redis(Apache环境 Php 5.4.34)

首先需要安装redis扩展,下载 dll文件,地址https://github.com/phpredis/phpredis/downloads
选择自己PHP对应的版本
比如 我是php5.4.34 ts版本(通过phpinfo(); 查看其中的 Thread Safety 项,这个项目就是查看是否是线程安全,如果是:enabled,一般来说应该是ts版,否则是nts版。)

下载后解压php_redis.dll 和 php_igbinary.dll 放入PHP的ext文件夹,配置文件php.ini里添加如下代码:

extension=php_igbinary.dll

extension=php_redis.dll

注意:
extension=php_igbinary.dll
extension=php_redis.dll
顺序为先调用php_igbinary.dll,顺序错了调用会失败
重启服务Apache
4、PHP中使用

代码如下

<?php
$redis = new Redis();
$redis->connect(‘127.0.0.1’,6379);
$redis->set(‘test’,’hello man’);
echo $redis->get(‘test’);
?>

输出 hello man

 

5、关于PHP的redis函数可以参考PHP Redis文档函数

MySQL中常用字符串函数

整理一些常用的Mysql sql语句字符串函数,资源来自互联网,亲测,很实用
1.字符串长度函数CHAR_LENGTH(str),LENGTH(str)
CHAR_LENGTH()返回值为字符串str的长度,长度的单位为字符。一个多字节字符算作一个单字符。对于一个包含五个二字节字符集,LENGTH() 返回值为 10, 而 CHAR_LENGTH() 的返回值为 5
select CHAR_LENGTH(‘你是’); –2
select LENGTH(‘你是’); –6

2.拼接函数
CONCAT(str1 ,str2 ,…):
返回结果为连接参数产生的字符串。如有任何一个参数为 NULL ,则返回值为NULL。

CONCAT_WS(separator ,str1 ,str2 ,…):
CONCAT_WS() 代表 CONCAT With Separator ,是 CONCAT() 的特殊形式。 第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL ,则结果为 NULL 。函数会忽略任何分隔符参数后的 NULL 值。

3.重复函数
REPEAT(str ,count):
函数使用说明:返回一个由重复的字符串str 组成的字符串,字符串str 的数目等于count 。 若 count <= 0, 则返回一个空字符串。若str 或 count 为 NULL ,则返回 NULL 。

4.查找位置函数
FIND_IN_SET(str, strlist)
假如字符串 str 在由 N 子链组成的字符串列表 strlist 中, 则返
回 值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被 ‘,’ 符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是 type SET 列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果 str 不在 strlist 或 strlist 为空字符串,则返回值为 0 。如任意一个参数为 NULL ,则返回值为 NULL。

INSTR(str,substr)
返回字符串 str 中子字符串的第一个出现位置。这和LOCATE() 的双参数形式相同,除非参数的顺序被颠倒。

LOCATE(substr ,str ) , LOCATE(substr ,str ,pos ):
第一个语法返回字符串 str 中子字符串substr 的第一个出现位置。第二个语法返回字符串 str 中子字符串substr 的第一个出现位置, 起始位置在pos 。如若substr 不在str 中,则返回值为0 。

5.截取函数
LEFT(str,len):
返回从字符串str 开始的len 最左字符

RIGHT(str ,len ):
从字符串str 开始,返回最右len 字符。

SUBSTRING(str ,pos ) , SUBSTRING(str FROM pos ) SUBSTRING(str ,pos ,len ) , SUBSTRING(str FROM pos FOR len ):
不 带有len 参数的格式从字符串str 返回一个子字符串,起始于位置 pos 。带有len 参数的格式从字符串str 返回一个长度同len 字符相同的子字符串,起始于位置 pos 。 使用 FROM 的格式为标准 SQL 语法。也可能对pos 使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。
select SUBSTRING(‘abcd’,-2); –cd
注:SUBSTRING() 等价于SUBSTR()

SUBSTRING_INDEX(str,delim,count)
在定界符 delim 以及count 出现前,从字符串str 返回自字符串。若count 为正值, 则返回最终定界符( 从左边开始) 左边的一切内容。若count 为负值,则返回定界符(从右边开始)右边的一切内容。
select SUBSTRING_INDEX(‘a,b,c’,’,’,2)     —  a,b 从开头到第2个,的串
SUBSTRING_INDEX(‘a,b,c’,’.’,-2)    —  b,c 从倒数第2个点开始的串

6.大小写转换函数
LCASE(str),LOWER(str)转化为小写
UCASE(str),UPPER(str)转化为大写

7.字符串替换函数
REPLACE(str ,from_str ,to_str)
返回字符串str 以及所有被字符串to_str 替代的字符串from_str
select REPLACE(‘abcabc’,’ab’,’e’); –ecec

8.反转函数REVERSE(str)
select REVERSE(‘abc’); –cba

9.去空格函数
select LTRIM(‘   abc’); –abc
select RTRIM(‘abc   ‘); –abc
TRIM([{BOTH | LEADING | TRAILING} [remstr ] FROM] str ):
返回字符串 str , 其中所有remstr 前缀和/ 或后缀都已被删除。若分类符BOTH 、LEADIN 或TRAILING 中没有一个是给定的, 则假设为BOTH
select TRIM(BOTH FROM’  a  b  ‘); –a  b

10.空格字符串
SPACE(N):返回一个由N个空格组成的字符串