请大神讲解下这段php代码,关于preg_replace_callback()函数
$str = preg_replace_callback(
"#\\\u([0-9a-f]{4})#i",
function($matchs)
{
return iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));
},
$str);
我搜了搜相关资料,懂了个大概,但是精髓部分还是不明白。
1)preg_replace_callback()函数第一个参数应该是个正则表达式,用来匹配相关字符。但是,其中的两个‘#’和最后的那个i我不是很明白,是为了什么?
2)第二个参数是个闭包里面的参数$matchs是系统指定的?还是随便给个参数名都行?例如function($a),还有这个地方只能是闭包么,可以用函数改写么?
3)关于这个$matchs,经过我测试输出,它是个数组.matchs[0]是u8fd8,matchs[1]是8fd8。这是怎么做到的?利用前面那个正则表达式我只能匹配到matchs[0]的结果,去掉u的工作和再用matchs[1]保留去掉u后的结果是谁做的?莫非是那个‘#’后的i?
Array
(
[0] => \u8fd8
[1] => 8fd8
)
4)`iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));经过输出,iconv()函数的返回值是还这个iconv()函数内部是怎么组装出来还的呢?内部的pack函数中的H4作用是什么?是怎么加到8FD8前面的。
新手问题较多请大神们,不吝赐教。感激不尽!
回复内容:
$str = preg_replace_callback(
"#\\\u([0-9a-f]{4})#i",
function($matchs)
{
return iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));
},
$str);
我搜了搜相关资料,懂了个大概,但是精髓部分还是不明白。
1)preg_replace_callback()函数第一个参数应该是个正则表达式,用来匹配相关字符。但是,其中的两个‘#’和最后的那个i我不是很明白,是为了什么?
2)第二个参数是个闭包里面的参数$matchs是系统指定的?还是随便给个参数名都行?例如function($a),还有这个地方只能是闭包么,可以用函数改写么?
3)关于这个$matchs,经过我测试输出,它是个数组.matchs[0]是u8fd8,matchs[1]是8fd8。这是怎么做到的?利用前面那个正则表达式我只能匹配到matchs[0]的结果,去掉u的工作和再用matchs[1]保留去掉u后的结果是谁做的?莫非是那个‘#’后的i?
Array
(
[0] => \u8fd8
[1] => 8fd8
)
4)`iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));经过输出,iconv()函数的返回值是还这个iconv()函数内部是怎么组装出来还的呢?内部的pack函数中的H4作用是什么?是怎么加到8FD8前面的。
新手问题较多请大神们,不吝赐教。感激不尽!
1 i 正则通配符 意思是 不区分大小写
2 $match变量名而已 可以随便写。一般这样使用
preg_replace_callback ( "/表达式/通配符", array($this,"a"), $string);
function a($m){
}
3 你没给匹配的字符串 无法回答
# 号可以替换成任何特殊符号, 只要不常见的就行, 你用 "~", "/", "#" 都是一样的, i表示不区分大小写
随便写, 不是一定要$match
iconv是编码转换函数
上面这段代码的功能只是用来把UCS-2BE字符格式的字符串转换成汉字的。
http://bbs.csdn.net/topics/39...
上一篇: 如何防止被人刷验证码?