Submitted by gouki on 2011, October 11, 9:51 AM
风雪之隅的博客现在也越来越被很多人知道了,当然这与他加入了php的开发组也有关系。这不,开始内爆了。
前两天我在纠正关于json_decode的问题时,看了一下在线手册,才发现json_decode有了第四个可选参数,把BIG_INT当成STRING来处理。
当然看json_decode的时候里面的参数介绍的不多。这不,昨天雪候鸟更新了N多博客,里面就介绍了两篇与JSON相关的东西:
1、让Json更懂中文(JSON_UNESCAPED_UNICODE)
2、JsonSerializable接口
其中第1篇就是我说的BIG_INT相关的那些附加参数,他这么说了:
XML/HTML代码
- 怎么样, 是不是让大家很开心的改动? 呵呵, 当然, Json在5.4还加入了: JSON_BIGINT_AS_STRING, JSON_PRETTY_PRINT, JSON_UNESCAPED_SLASHES等选项, 如果有兴趣, 大家可以参看: json_encode
所以,比如让中文输出的时候不要变成\uxxxx这种格式就只需要这样:
PHP代码
- <?php
- echo json_encode("中文", JSON_UNESCAPED_UNICODE);
- ,如果没加这个参数,以前输出是:
然后JSONSerialize,则是有点象serialize了,但是只针对数据输出,而不是象serialize可以把整个对象序列化。。有点象这样:
PHP代码
- <?php
- class JsonTest implements JsonSerializable { //看一下这里
- private $a, $b;
-
- public function __construct($a, $b) {
- $this->a = $a;
- $this->b = $b;
- }
-
- public function jsonSerialize() { //也就是说这里要主动实现
- return $this->a + $this->b;
- }
- }
-
- echo json_encode(new JsonTest(23, 42));
- ?>
-
-
在使用的时候就可以这样:
PHP代码
- <?php
- $data = array(
- new stdClass();
- new JsonTest(1,2),
- new JsonTest(3,4),
- array(5,6)
- );
- echo json_encode($data);
- ?>
-
-
雪候鸟也说了:最后提醒一下, PHP 5.4还处于开发阶段, 在最终release之前, 这些特性都可能被调整或者更改. 如果大家有任何建议, 也欢迎反馈, 帮助我们使得PHP变得更好.
------
好吧,第一个功能我喜欢,第二个我短时间内还用不到。。。
Tags: 雪候鸟, json
PHP | 评论:1
| 阅读:18322
Submitted by gouki on 2011, October 10, 10:04 AM
介绍这个项目不是因为这个项目很好,主要是其实有一些地址我也不太清楚,但是既然我转载了,那就干脆把原作者的这个项目也介绍一下下喽:
作者主页: http://blog.lyphp.com
项目在:https://github.com/faxiandi/DengLuTong
在项目中需要用微博等帐号登录,便做了此登录通,从最开始只有新浪微博慢慢扩充到现在支持11个网站。 目前只有登录功能,以后会慢慢扩充。 如要与现有系统整合,需根据情况修改lib/local/local.php。
系统需求
php>=5.3 mysql(如需使用其他数据库,请修改自定义相应操作类,参照DBMYSQL.PHP)
安装
DengLuTong\DLTConfig.php中修改数据库信息、app key(对应KEYID)、app secret(对应SECID),根据实际情况修改url地址。 在数据库中添加用户绑定表,结构在DengLuTong.sql中。
演示
index.php,login.php,logout.php,reg.php为示例程序文件。示例用户表结构在DengLuTong.sql中。
API申请地址
天涯 http://open.tianya.cn/
腾讯 http://connect.opensns.qq.com/
淘宝 http://open.taobao.com/
Google OAUTH https://www.google.com/accounts/ManageDomains
开心网 http://www.kaixin001.com/platform/rlink/rlink_create.php
搜狐 http://open.t.sohu.com/
网易 http://open.t.163.com/
豆瓣 http://www.douban.com/service/apikey/apply
MSN https://manage.dev.live.com/
人人网 http://dev.renren.com/
新浪 http://open.weibo.com/
盛大 http://connect.open.sdo.com/
YAHOO https://developer.apps.yahoo.com/projects
支付宝 https://b.alipay.com/order/hot.htm
---------------------
这些API的地址才是我真正想要转载的。
PHP | 评论:1
| 阅读:15652
Submitted by gouki on 2011, October 8, 6:57 PM
今天同事突然和我说,腾讯微博无法访问了。但新浪微博接口却是正常的。
打开指定的URL,发现报错,仔细看了一下代码,居然是
if(!is_array($jsonDecode)){
throw new Exception("xxxx");
}
当发现json解析出来不是数组的时候,直接抛出异常。
可是我把json字符串在decode前输出的时候是正常的,那是为什么呢?为什么我var_dump出来是null?
看了一下手册,居然说var_dump出来null的原因是因为deepth不够,但看了一下手册,好象也就三个取值范围,128,512,1024,于是我设为最大的1024,但仍然失败。
然后,突然发现,居然json_decode有第四个参数,把BIGINT当成字符串。以为是这个问题导致的,兴冲冲的把这个参数加上去,结果报错,看了一下手册,原来这个参数居然是PHP 5.4才有的。。。
----
再测试,把文本拷成字符串,运行json_decode,居然正常了。这时候我就纳闷了。为什么直接处理不正常。拷成字符串就正常了。
仔细检查。居然发现里面有中文被截断的字符串。晶,肯定是这个原因了。。。
于是写正则,把这玩意替换掉,把A\d{3};的字符串都替换成空格。然后再反处理回去。。结果仍然失败,这时候我就在想一个问题,为什么会有这种情况?
最终我确定,绝对是编码,一定是那个不正常的字符串导致了原来的json字符串被错误的识别成了ISO-8900-1,所以我啥也没处理,直接把json字符串mb_convert_encoding($str,"UTF-8","auto"),自动转换成utf-8,果然json_decode,顺利的转换成了数组。
---
纠结了一天的事情,居然就是这样的小,所幸解决了。
Tags: json_decode, 腾讯微博
PHP | 评论:1
| 阅读:17737
Submitted by gouki on 2011, September 30, 10:16 PM
之前在博客里有提过basename的事情,蜘蛛也说过这个函数处理中文有问题。我也在测试的过程中遇到过各种各样的问题,但总体来说,我现在在处理中文文件名的时候是直接 array_pop(explode("/",$filename));
今天在群里,echo也说了这个问题,他居然还贴了SVN中PHP的源码关于basename的一段,并指出问题在php_mblen 这个函数上:他说mblen发现全中文的时候会返回负数。
于是他说有个临时的解决方案是:
XML/HTML代码
- echo 22:00:11
- ltrim(basename(' ' . $filename))
- 骗过mblen() ,mblen全中文的时候,返回的是负数。
- 有一个空格就好 了
没有试过,希望能够解决问题。
然后日哥说,可以用exif_read来解决这个问题,可以取得图片的title,但echo直接无视,因为不是每个上传的文件都是图片,可以通过 Exif_read解决这个问题。
echo也说了,别妄想用pathinfo解决这个问题,因为源码里显示,这个函数最 后还是调用了php_basename,所以他们的问题其实是一样的。。。。
=------纯记录----
Tags: basename, pathinfo
PHP | 评论:0
| 阅读:23123
Submitted by gouki on 2011, September 27, 12:10 AM
事实上,我一般用的最多的就是Post-Commit,因为用来将SVN里的代码提交到测试机的项目里。其实也听过用svn来检测代码的可执行性。不过我是没有用过啦。
老王在博客里写的这篇文章就是讲pre-commit。有借鉴意义,以后可以悄悄的程序里用。不过,我觉得检查语法这种事情其实可以忽略了,毕竟现在都是用IDE的,一般语法问题IDE都能认出来。。
注:我开始看文章的时候没有仔细看CodeSniffer,我起初认为是语法检测,事实并非这样,是指代码是否按规范来写代码。如果是这样,那值得搞一搞啊
OK,上原文:Subversion钩子
Subversion本身有很好的扩展性,用户可以通过钩子实现一些自定义的功能。
所谓钩子实际上是一种事件机制,当系统执行到某个特殊事件时,会触发我们预定义的动作,这样的特殊事件在Subversion里有很多,默认有如下模板可供选择:
XML/HTML代码
- shell> ls /path/to/repository/hooks
- post-commit.tmpl
- post-lock.tmpl
- post-revprop-change.tmpl
- post-unlock.tmpl
- pre-commit.tmpl
- pre-lock.tmpl
- pre-revprop-change.tmpl
- pre-unlock.tmpl
- start-commit.tmpl
其中最常用的是pre-commit和post-commit,也就是提交前后的钩子,下面以pre-commit为例来说明一下如何自定义Subversion钩子。
假设有一个PHP项目使用Subversion做版本控制,使用中发现了一些问题,比如程序员不写日志,或者提交的文件有BOM,或者提交的文件有语法错误,或者提交的文件不符合编码规范等等,这些问题都可以利用pre-commit钩子来解决,实际上已经有人写了解决类似问题的工具php-svn-hook,不过我们这里选择自己实现:
XML/HTML代码
- shell> cat /path/to/repository/hooks/pre-commit
- #!/bin/bash
-
- REPOS="$1"
- TXN="$2"
-
- SVNLOOK="/usr/bin/svnlook"
- PHP="/usr/bin/php"
-
- LOG=$($SVNLOOK log -t "$TXN" "$REPOS")
-
- if [ "$LOG" = "" ]; then
- echo "Please input log" 1>&2
- exit 1
- fi
-
- FILES=$($SVNLOOK changed -t "$TXN" "$REPOS" | awk '/^[AU]/ {print $NF}')
-
- for FILE in $FILES; do
- CONTENT=$($SVNLOOK cat -t "$TXN" "$REPOS" "$FILE")
-
- if echo "$CONTENT" | grep -q $'\xEF\xBB\xBF'; then
- echo "Please remove BOM from $FILE" 1>&2
- exit 1
- fi
-
- if [[ "$FILE" =~ \.(php|html)$ ]]; then
- MESSAGE=$(echo "$CONTENT" | $PHP -l 2>&1)
-
- if [ $? -ne 0 ]; then
- echo "$MESSAGE" | sed "s/ -/ $FILE/g" 1>&2
- exit 1
- fi
- fi
- done
-
- /path/to/PHP_CodeSniffer/scripts/phpcs-svn-pre-commit "$REPOS" -t "$TXN" 1>&2 || exit 1
-
- exit 0
注:代码里使用PHP_CodeSniffer检查编码规范。
配置好脚本后,一定要记着给脚本加上可执行属性,不然脚本执行后会显示不知所云的错误信息:svn: Commit blocked by pre-commit hook (exit code 255) with no output。
本文以pre-commit为例说明了一下钩子的用法,实际上其他脚本也很有用,比如说如果你想在提交代码后发一条微博,就可以利用post-commit来解决,大家自己领悟吧。
--------
主要还是对bash不熟,否则post-commit里的代码我也不至于是直接改成svn-update的代码了。
学习学习
PHP | 评论:0
| 阅读:17286