我的备忘录


Wordpress 2.5.1 500 错误解决方法

Posted in php by Kafeifei on the 05月 1st, 2008

随时听人讲有500错误。
今天在楚云blog上重现了。
抓住机会debug。
结果很快出来:
当你第二次用同样的标题并且标题中含有多字节文字时,有很大机会触发wp一个死循环,然后服务器cpu直接到100%,当运行时间超过max_execution_time时候出现500错误。
死循环在这里:wp-include/post.php

<?php
......
if ( 'draft' != $post_status ) {
    $post_name_check = $wpdb->get_var($wpdb->prepare("SELECT post_name FROM $wpdb->posts WHERE post_name = %s AND post_type = %s AND ID != %d AND post_parent = %d LIMIT 1", $post_name, $post_type, $post_ID, $post_parent));

    if ($post_name_check || in_array($post_name, $wp_rewrite->feeds) ) {
        $suffix = 2;
        do {
            $alt_post_name = substr($post_name, 0, 200-(strlen($suffix)+1)). "-$suffix";
            // expected_slashed ($alt_post_name, $post_name, $post_type)
            $post_name_check = $wpdb->get_var($wpdb->prepare("SELECT post_name FROM $wpdb->posts WHERE post_name = '$alt_post_name' AND post_type = '$post_type' AND ID != %d AND post_parent = %d LIMIT 1", $post_ID, $post_parent));
            $suffix++;
        } while ($post_name_check);
        $post_name = $alt_post_name;
    }
}

死循环触发点:wp-include/wp-db.php

<?php
......
/**
 * Prepares a SQL query for safe use, using sprintf() syntax
 */
function prepare($args=NULL) {
    if ( NULL === $args )
    return;
    $args = func_get_args();
    $query = array_shift($args);
    $query = str_replace("'%s'", '%s', $query); // in case someone mistakenly already singlequoted it
    $query = str_replace('"%s"', '%s', $query); // doublequote unquoting
    $query = str_replace('%s', "'%s'", $query); // quote the strings
    array_walk($args, array(&$this, 'escape_by_ref'));
    return @vsprintf($query, $args);
}

post_name 中的的多字节文字被 urlencode 成这样 "%e6%88%91%e6%93%8d%ef%bc%81",只要 % 后面跟了 bcdeufFosxX 中任意一个(覆盖了大半个中文区域),就造成 vsprintf 函数调用失败,返回 false,而上层的循环一直在等它返回一个非false的值,直到程序死掉。

解决方法很简单:
修改 wp-include/wp-db.php
用下面的代码替换掉之前贴出的代码:

<?php
......
/**
 * Prepares a SQL query for safe use, using sprintf() syntax
 */
function prepare($args=NULL) {
    if ( NULL === $args )
    return;
    $args = func_get_args();
    $query = array_shift($args);
    $query = str_replace("'%s'", '%s', $query); // in case someone mistakenly already singlequoted it
    $query = str_replace('"%s"', '%s', $query); // doublequote unquoting
    $query = str_replace('%s', "'%s'", $query); // quote the strings
    array_walk($args, array(&$this, 'escape_by_ref'));

    // 旧的方法会引起其他问题
    // $query = preg_replace("#(%[0-f]{2})#sie", "urldecode('$1')", $query);
    // $query = @vsprintf($query, $args);
    // $query = preg_replace("#([\x80-\xff])#se", "strtolower(urlencode('$1'))", $query);

    // 新的方法只针对重复标题时的死循环问题
    $reg = "#post_name = '((?:%[0-9a-f]{2})+.+)'#Usi";
    if (preg_match($reg, $query, $match)) {
        $he = $match[1];
        $hd = urldecode($he);
        $query = str_replace($he, $hd, $query);
        $query = @vsprintf($query, $args);
        $query = str_replace($hd, $he, $query);
    } else {
        $query = @vsprintf($query, $args);
    }

    return $query;
}

后来楚云坚持认为wp可以不用修改任何原始代码解决所有问题,所以找到了下面的方法:
下载这个文件:db.tgz 解压后得到 db.php 将它放到 wp-content/ 下。
---------
或许这只是其中一个造成500的原因,下次遇到再说吧。
--------- update --------
补充,此db.php为2.5.1的,后来才知道2.5.1比2.5.0也有更新,不保证其他版本没有意外情况。
--------- update 2008/05/10 --------
发现bug,更新了方法以及db.php下载链接。以前的方法太粗暴,一些其他的查询也被强制转码造成数据错误。
解决方法:重新下载db.php或按照前文代码重新修改wp-db.php。已经出错的数据,可重新编辑保存。已知会引发错误的地方:http://yourwpuri/wp-admin/widgets.php (也就是说你使用了之前的 db 文件后,有设置过 widgets 功能,最好重新设置一遍)

新装 Leopard 安装开发环境全记录

Posted in MacosX by xdanger on the 03月 16th, 2008

前期工作

安装光盘里的 Xcode,或者下载 iPhone SDK,2.1G,包括了最新的 Xcode 和 iPhone SDK。

安装好后会有 apache-2.2.6 / php-5.2.5 / ruby-1.8.6 / rails-1.2.6 / python-2.5.1 / java-1.5.0_13 / sqlite-3.4.0 …… gcc 会有2个版本:4.0.14.2.1,默认 /usr/bin/gcc 软连到 gcc-4.0,我们先让默认的 gcc 改用 4.2(2007年1月就 release 了,Changelog

cd /usr/bin
sudo unlink gcc
sudo ln -s gcc-4.2 gcc

设置全局编译参数,编辑 /etc/profile,加上下面的全局变量,保存后重启终端

export MACOSX_DEPLOYMENT_TARGET=10.5
export ARCHFLAGS='-arch x86_64'
export CFLAGS='-arch x86_64 -O3 -pipe'
export CXXFLAGS=$CFLAGS
export LDFLAGS='-arch x86_64 -bind_at_load'

如果需要编译兼容 i386、ppc、ppc64 版本的(编译出来的文件会增大不少),只要加上相应的 -arch 即可

export CFLAGS="-arch ppc -arch ppc64 -arch i386 -arch x86_64 -O3 -pipe"
export CXXFLAGS=$CFLAGS
export LDFLAGS="-arch ppc -arch ppc64 -arch i386 -arch x86_64 -bind_at_load"

如果需要编译针对 CPU 优化的,Apple 全系列已经升级到 Intel Core Duo,所以可以加上以下参数

CHOST="x86_64-pc-linux-gnu"
CFLAGS="-march=nocona -O2 -pipe"
CXXFLAGS="${CFLAGS}"

-O 使用 O3,其他详见 http://www.gentoo-wiki.com/Safe_Cflags

因此我自己编译的最终参数是

export MACOSX_DEPLOYMENT_TARGET=10.5
export ARCHFLAGS='-arch x86_64'
export CFLAGS='-arch x86_64 -march=nocona -pipe -O3 -pipe'
export CXXFLAGS=$CFLAGS
export LDFLAGS='-arch x86_64 -bind_at_load'

Java

虽然 Apple 总算在 2008年2月 放出了 JDK6 Preview,但是问题还是非常多。我们还是用 BSD 的一个移植版本 Soylatte,直接下载 64-bit JDK for Mac OS X 10.5: soylatte16-amd64-1.0.2.tar.bz2 (Username: 'jrl',Password: 'I am a Licensee in good standing')
解压后放到 /usr/local/soylatte16-amd64,软连 /usr/local/java 到这个目录:

cd /usr/local; sudo ln -s soylatte16-amd64 java
cd /System/Library/Frameworks/JavaVM.framework/Versions/; sudo mkdir soylatte16-amd64
cd soylatte16-amd64; sudo ln -s /usr/local/java Home; sudo ln -s ./Home/bin ./Commands
cd ../A; sudo mv Commands Commands.bak; sudo ln -s ../CurrentJDK/Commands ./
cd ..; sudo unlink CurrentJDK; sudo ln -s soylatte16-amd64 CurrentJDK
java -version

显示如下,Java 就算搞定了

java version "1.6.0_03-p3"
Java(TM) SE Runtime Environment (build 1.6.0_03-p3-landonf_03_feb_2008_01_32-b00)
Java HotSpot(TM) 64-Bit Server VM (build 1.6.0_03-p3-landonf_03_feb_2008_01_32-b00, mixed mode)

基本库和命令

libtool

curl http://ftp.gnu.org/gnu/libtool/libtool-1.5.26.tar.gz &gt; libtool-1.5.26.tar.gz
tar xzf libtool-1.5.26.tar.gz
cd libtool-1.5.26
./configure
make
sudo make install

zlib

curl http://www.zlib.net/zlib-1.2.3.tar.gz &gt; zlib-1.2.3.tar.gz
tar xzf zlib-1.2.3.tar.gz
cd zlib-1.2.3
./configure
make
sudo make install

openssl/libssl

curl http://www.openssl.org/source/openssl-0.9.8g.tar.gz &gt; openssl-0.9.8g.tar.gz
tar xzf openssl-0.9.8g.tar.gz
cd openssl-0.9.8g
./config --prefix=/usr/local --openssldir=/openssl threads zlib-dynamic
vi Makefile
# OPTIONS 里去掉 no-sse2 来开启 CPU 的 SSE2 指令集支持
# CFLAG 里 -arch i386 改为 -arch x86_64
# SHARED_LDFLAGS 同上
make
sudo make install
cd /usr/local/bin
sudo ln -s ../openssl/bin/* ./

wget

curl http://ftp.gnu.org/gnu/wget/wget-1.11.tar.bz2 &gt; wget-1.11.tar.bz2
tar xjf wget-1.11.tar.bz2
cd wget-1.11.tar.bz2
./configure --with-libssl-prefix=/usr/local/openssl
make
sudo make install

libpng

wget http://downloads.sourceforge.net/libpng/lpng1225.tar.bz2 -O libpng-1.2.25.tar.bz2
tar xjf libpng-1.2.25.tar.bz2
cd libpng-1.2.25
./configure
make
sudo make install

libjpeg

wget http://freshmeat.net/redir/libjpeg/5665/url_tgz/jpegsrc.v6b.tar.gz
tar xzf jpegsrc.v6b.tar.gz
cd jpeg-6b
cp /usr/share/libtool/config.sub .
cp /usr/share/libtool/config.guess .
./configure --enable-shared --enable-static
make
sudo mkdir -p /usr/local/man/man1
sudo make install -lib

freetype

wget http://download.savannah.gnu.org/releases/freetype/freetype-2.3.5.tar.gz
tar xzf freetype-2.3.5.tar.gz
cd freetype-2.3.5
./configure
make
sudo make install

fontconfig

wget http://fontconfig.org/release/fontconfig-2.5.91.tar.gz
tar xzf fontconfig-2.5.91.tar.gz
cd fontconfig-2.5.91
./configure --prefix=/usr/local --with-zlib --with-jpeg --with-png --with-freetype --disable-dependency-tracking
make
sudo make install

gd2

wget http://www.libgd.org/releases/gd-2.0.35.tar.bz2
tar xjf gd-2.0.35.tar.bz2
cd gd-2.0.35
./configure --with-fontconfig=/usr/local/bin --disable-dependency-tracking
make
sudo make install

ImageMagick

wget ftp://ftp.imagemagick.org/pub/ImageMagick/ImageMagick-6.3.9-7.tar.bz2
tar xjf ImageMagick-6.3.9-7.tar.bz2
cd ImageMagick-6.3.9
./configure --with-fontconfig
make
sudo make install

mysql

wget http://dev.mysql.com/get/Downloads/MySQL-5.0/mysql-5.0.51a.tar.gz/from/http://mirror.services.wisc.edu/mysql/
tar xzf mysql-5.0.51a.tar.gz
cd mysql-5.0.51a
./configure --with-mysql-user=mysql --with-mysql-group=mysql --with-innodb --with-archive-storage-engine --with-ndbcluster --with-zlib-dir=/usr/local --with-pthread --with-extra-charsets=utf8 --disable-dependency-tracking
make
sudo make install

neon

wget http://www.webdav.org/neon/neon-0.25.5.tar.gz
tar xzf neon-0.25.5.tar.gz
cd neon-0.25.5
./configure --with-ssl=openssl
make
sudo make install

Berkeley DB

# 为了让 subversion-1.4.6 使用,只能用 db-4.4 版本的
wget http://download.oracle.com/berkeley-db/db-4.4.20.tar.gz
tar xzf db-4.4.20.tar.gz
cd db-4.4.20/build_unix
make
sudo make install
cd /usr/local/; sudo ln -s BerkeleyDB.4.4 bdb

subversion

wget http://apache.mirror.phpchina.com/httpd/httpd-2.2.8.tar.bz2
tar xjf httpd-2.2.8.tar.bz2
wget http://subversion.tigris.org/downloads/subversion-1.4.6.tar.bz2
tar xjf subversion-1.4.6.tar.bz2
cd subversion-1.4.6
cp -r ../httpd-2.2.8/srclib/apr* ./
./configure --with-apxs=/usr/sbin/apxs --with-berkeley-db=/usr/local/bdb --with-ssl
make
sudo make install

libevent

wget http://www.monkey.org/~provos/libevent-1.4.2-rc.tar.gz
tar xzf libevent-1.4.2-rc.tar.gz
cd libevent-1.4.2-rc
./configure
make
sudo make install

memcached

wget http://www.danga.com/memcached/dist/memcached-1.2.5.tar.gz
tar xzf memcached-1.2.5.tar.gz
cd memcached-1.2.5
./configure
make
sudo make install

pcre

wget http://nchc.dl.sourceforge.net/sourceforge/pcre/pcre-7.6.tar.bz2
tar xjf pcre-7.6.tar.bz2
cd pcre-7.6
./configure --enable-utf8
make
sudo make install

pkg-config

wget http://pkgconfig.freedesktop.org/releases/pkg-config-0.23.tar.gz
tar xzf pkg-config-0.23.tar.gz
cd pkg-config-0.23
make
sudo make install
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:/usr/lib/pkgconfig

libxml2

wget ftp://xmlsoft.org/libxml2/libxml2-2.6.31.tar.gz
tar xzf libxml2-2.6.31.tar.gz
cd libxml2-2.6.31

lighttpd

wget http://www.lighttpd.net/download/lighttpd-1.4.19.tar.bz2
tar xjf lighttpd-1.4.19.tar.bz2
cd lighttpd-1.4.19
./configure --with-openssl --with-zlib --without-bzip2 --with-pcre  --with-gdbm --with-memcache --with-ldap
make
sudo make install

好像大功告成了,还缺啥嘛?

iphone 1.1.3/1.1.4 完美破解指南

Posted in Bsd, MacosX, Unix, shell by Kafeifei on the 03月 15th, 2008

首先用itunes将iphone升级至1.1.3/1.1.4
然后运行ziphone激活,破解,解锁……
安装openssh
root登陆,密码:alpine
安全起见 #chmod -x /usr/bin/passwd
这里生成密码,salt为/s,用它替换root密码(/etc/master.passwd)
然后移动 /Application /Library 到第二分区

关羽、张飞的武功的来历

Posted in 8diagrams by xdanger on the 03月 14th, 2008

看三国最让人不解的是那些超一流武将从一登场就有超一流的武功,至于这些武功是怎么来的,罗老先生却惜墨如金,不像金庸的人物,武功都是一天天炼出来的。即使如全庸金康之流,笔下人物也还能喝点蛇血什么的,内功一下暴涨60年,总算有个交待。

三国武将的武功自然不是喝蛇血喝出来的,那是不是一天天炼出来的呢?武将之中,张飞关羽的早期经历写的稍微多一点,我们就以这哥俩为例作一分析。

张飞简历:“某姓张,名飞,字翼德。世居涿郡,颇有庄田,卖酒屠猪,专好结交天下豪杰。恰才见公看榜而叹,故此相问。”

关羽简历:“吾姓关,名羽,字长生,后改云长,河东解良人也。因本处势豪,倚势凌人,被吾杀了;逃难江湖,五六年矣。今闻此处招军破贼,特来应募。”

两位都没有提自己的武功,连“自幼习武”这句都没说。更重要的是随后的情节。刘关张决定起兵后,“云长造青龙偃月刀,又名”冷艳锯“,重八十二斤。张飞造丈八点钢矛。”你看,在这之前,两位连兵器都没有。关羽还好说,毕竟扛着八十二斤的大刀逃难有点困难。张飞就不该了,有钱有房,要是练武,不至于连一杆像样的矛都造不起。

可见他们平时并不练武。

那关羽张飞的武功到底是怎么来的呢?

他们的武功来自他们的职业!

据北京体育大学武术学院的网站,“马克思主义认为,人类的生产活动是最基本的实践活动,是决定其他一切活动的东西。武术的产生,从来就是有生产活动决定的。”

关羽张飞也不能有例外。

汉末,武术还没有系统化,不具备通过向师傅学习成为武林高手的条件。要想成为高手,一要有天生体格,二要悟性高,能从生产活动中领悟攻防技术。以此为指导,我们来分析张飞关羽的武功与职业的关系。

张飞的主要职业是杀猪。杀猪要用杀猪刀。和张飞的兵器不同,但技术特点一致。杀猪时不是用杀猪刀砍,而是捅。所以本质上杀猪刀不是刀,而是和矛类似。猪杀死后要去毛,去毛前要给猪充气,使皮肤绷紧。通常做法是用铁钎从后啼一直捅到腹部,然后拔出铁钎,往腹部充气。张飞没有打气筒,只能用嘴吹。铁钎就是小号的矛,所以张飞自然选矛作武器。

另外,长期给猪吹气,张飞练就了巨大的肺活量,才能在长板坡前一声吼,吓退曹操百万兵。

三国演义中没有提关羽的职业,但大家都知道,关羽在逃亡途中卖过枣。卖了五六年的枣,怎么说也是一种职业了。关羽不擅生意,买不出好价钱,但仍能维持生计,说明其进货渠道不一般。如果正常付款进货,本钱早就陪光了。关羽有案在身,不大可能去抢枣。再说,要抢也应该去抢钱。关羽只能自己去枣园打枣。枣园是地主豪强的,打他的枣就是斗地主,不用付钱,心安理得。为了少惹麻烦,关羽总是穿一身绿,见有人来,便爬到枣树上躲起来。一身绿衣,一张枣红脸,藏在枣树上谁也别想看着。

想必关羽不会爱惜枣树,只顾拿大竹竿一通猛打。上高中时半夜拿大竹竿偷过学校的柿子,深知在枝叶中挥动竹竿需要多大的力气。关羽如此打了五六年,练就无穷臂力。从技术特点看,挥动竹竿和挥动大刀完全相同。所以关羽选择了八十二斤的大刀。

打枣成就了关羽的武功,也造成关羽武功的严重缺陷。

关羽曾和赵云在牛头山打过一仗。这场战斗发生在一条山道上,山道两旁全是树。

“关羽奋然上马,倒提青龙刀,凤目圆睁,蚕眉直竖,直冲卧牛山。遍山树枝如波开浪裂,关公径奔一白杨树。赵云见关羽不来斗将,却入无人之境,方欲问时,关羽赤兔马快,早到树前,手起一刀,将白杨树折做两段。”

关羽的武功源自打枣。在冲锋时精神高度集中,道旁的树木钩起了本能反应,挥刀直奔树木而去,大大出了一回洋相。

关羽也因此弱点被擒,丢了性命。

关羽冲出麦城,沿一条山路逃跑,不想赤兔马被绊倒,关羽落马被马忠所擒。关羽即使落马,但功夫仍在,马忠乃无名之辈,如何擒得关羽?想马超也曾步战,杀得韩遂及手下五将血肉横飞。关羽虽疲惫,对付一个马忠理应绰绰有余。怎奈又是山路,山路两旁又是树木。关羽举刀欲战,却见两旁树木众多,一时不知该砍哪棵。犹豫半分钟,早被马忠绑定。

总结:通过分析关羽张飞的武功特点及典型战例,我们得出结论,关羽张飞的武功源自他们的职业。我们相信该结论可推广到所有三国武将。根据此结论,我们可以分析各武将的弱点,从而设计合理战术,轻松打败他们。

交叉编译jpeg库的问题

Posted in bash by xdanger on the 03月 11th, 2008
./configure --enable-shared --enable-static

加了 --enable-shared 或者 --enable-statics 就会报

ltconfig: cannot guess host type; you must specify one

方法是安装最新版的 libtool 然后

cp /usr/share/libtool/config.sub . 
cp /usr/share/libtool/config.guess . 
./configure --enable-shared --enable-static 
make; make install

洪七公生平简介

Posted in 8diagrams by xdanger on the 02月 12th, 2008

  洪七公原名洪七,他不光杀了王重阳,江南5怪其实都是他杀的
  
  王重阳的秘密是他偷走了辟邪剑法,然后就亲自练了,他无法躲闪林朝英的纠缠,就只好以 "国将不国,何以家为" 的口号躲避她,由于练了辟邪剑法,王重阳轻功极高,再加上他爱吃素食,整天神神秘秘的,所以大家叫他 "中神通。"
  
  中神通有一个徒弟,一个传授了辟邪剑法的徒弟,就是洪七, 由于洪七也自宫了,所以中神通叫他 "洪七公公"
  
  师徒二人惺惺相惜,到也相处的融洽,直到有一天,中神通的辟邪剑法练到了东方不败的地步,他开始把洪( 练辟邪剑法的人最终会发展到两个层次,一是东方不败的类型,就是对别人有性骚扰的, 二是岳不群,林平之类型的,对别人无害)
  
  洪七公公迫不得己杀了中神通,碰巧给江南7怪撞见了,7怪看到辟邪剑法怪异的情景,急忙逃跑了, 而洪七公公只看到了7个人的身影,作贼心虚,就没有追赶。
  
  江南7怪害怕辟邪剑法,一直跑到了大漠,于是就躲了起来,他们一边训练郭靖,一边苦练功夫,时刻准备敌人来灭口,这一躲就是18年.
  
  中神通已死,全真教也待不下去了,洪七公公还要暗中查访那七个人,到哪里立足呢?,丐帮是个好去处,入丐帮的时候,他将名字中一个’公‘字去掉,就成了洪七公
  
  洪七公生性好学,每天勤学苦练,他一腔精力无处发泄,加上辟邪剑法的轻功,洪七公很快就练就了打狗棒法和降龙18掌,并且当上了丐帮帮主

Leopard 编译 universal php5

Posted in Bsd, MacosX, Unix, bash, php by Kafeifei on the 12月 11th, 2007

因为自带的php没有gd所以要重编
因为服务器用的是x86_64 httpd+php5所以要编 x86_64
因为自带的httpd+php是 universal ,所以要这样做
自带的httpd很好,所以不搞它了
参考:
ppc就不要了

export MACOSX_DEPLOYMENT_TARGET=10.5
export ARCHFLAGS='-arch i386 -arch x86_64'
export CFLAGS='-arch i386 -arch x86_64 -O3 -pipe'
export CXXFLAGS='-arch i386 -arch x86_64 -O3 -pipe'
export LDFLAGS='-arch i386 -arch x86_64 -bind_at_load'

make时候可能出现这样的提示:

gcc-4.0: -E, -S, -save-temps and -M options are not allowed with multiple -arch flags

在 configure 的时候加上 --disable-dependency-tracking

'./configure' \
'--prefix=/usr' \
'--with-config-file-path=/private/etc' \
'--sysconfdir=/private/etc' \
'--with-apxs2=/usr/sbin/apxs' \
'--with-iconv=/usr/local' \
'--with-mhash=/usr/local' \
'--with-gettext=/usr/local' \
'--with-mysql=/usr/local' \
'--with-mysqli=/usr/local/bin/mysql_config' \
'--with-pdo-mysql=/usr/local' \
'--with-openssl=/usr' \
'--with-zlib=/usr' \
'--with-curl=/usr' \
'--with-gd' \
'--with-png-dir=/usr/X11' \
'--with-jpeg-dir=/usr/local' \
'--with-freetype-dir=/usr/X11' \
'--with-xpm-dir=/usr/X11' \
'--enable-gd-native-ttf' \
'--enable-mbstring' \
'--enable-sockets' \

已有的库就不重装了,只需自己安装 gawk, libiconv, mhash, gettext, mysql, jpeg
需要特别注意:系统自带的liviconv有问题,需要自己编一份到/usr/local(小心不要覆盖以前的,否则可能连sh都不能执行了),php在configure时就算指定了 --with-iconv=/usr/local 它还是首先找到 /usr/include/iconv.h ,而且 --help 里只提到 --with-iconv-dir=,应该使用 --with-iconv=
解决方法:

sh#mv /usr/include/iconv.h /usr/include/iconv.h.bak

Macosx Universal Binaries 减肥瘦身

Posted in MacosX by Kafeifei on the 11月 11th, 2007

三种方法

ditto –rsrc –arch i386 /Applications/Foo.app /Application/Foo-ppc.app
lipo -thin i386
lipo -remove ppc

iPhone的通讯录以拼音排序

Posted in MacosX, php, shell by Kafeifei on the 10月 6th, 2007

在iphone中安装php
将代码保存为py.php
ssh 登陆iphone或者在iphone安装Term-vt100
执行 php py.php 等待重启完成
结束

支持的中文貌似很有限,拼音表的处理看来要自己搞一个了,这个在网上找的。

py.php

<?php
/**
 * @desc 将iPhone的通讯录以拼音排序, 需要安装PHP
 * @author Kafeifei <http://www.nimab.org>
 * @version 0.2beta
 */
error_reporting(0);
$sqlite_file = '/private/var/root/Library/AddressBook/AddressBook.sqlitedb'; // 1.1.3 以前的版本
$sqlite_file = '/private/var/mobile/Library/AddressBook/AddressBook.sqlitedb'; // 1.1.3 以后的版本
if (!file_exists($sqlite_file)) {
	println("SQLiteDB:File Notfound.");
	die;
}
$dsn = "sqlite:{$sqlite_file}";
try {
    $dbh = new PDO($dsn);
    println("Open {$dsn}   OK.");
} catch (Exception $e) {
    println("Open {$dsn}   ERROR:".$e->getMessage());
    die;
}
$stmt = $dbh->query("SELECT ROWID, First, Last FROM ABPerson");
while ($person = $stmt->fetch(PDO::FETCH_ASSOC)) {
	$first = ucfirst(Py::parse(u2g($person['First'])));
	$last  = ucfirst(Py::parse(u2g($person['Last'])));
	$dbh->query("update ABPerson set FirstSort='{$first}', LastSort='{$last}' where ROWID = {$person['ROWID']} ;\n");
	println("{$person['ROWID']}\tOK.");
}
println("done.");
println("rebooting...");
system('launchctl stop com.apple.SpringBoard');

function u2g($str) {
    return iconv('utf-8', 'gbk', $str);
}

function println($str) {
    echo "$str\n";
    flush();
}

class Py {
    private static $table = array(
        array("a",-20319),
        array("ai",-20317),
        array("an",-20304),
        array("ang",-20295),
        array("ao",-20292),
        array("ba",-20283),
        array("bai",-20265),
        array("ban",-20257),
        array("bang",-20242),
        array("bao",-20230),
        array("bei",-20051),
        array("ben",-20036),
        array("beng",-20032),
        array("bi",-20026),
        array("bian",-20002),
        array("biao",-19990),
        array("bie",-19986),
        array("bin",-19982),
        array("bing",-19976),
        array("bo",-19805),
        array("bu",-19784),
        array("ca",-19775),
        array("cai",-19774),
        array("can",-19763),
        array("cang",-19756),
        array("cao",-19751),
        array("ce",-19746),
        array("ceng",-19741),
        array("cha",-19739),
        array("chai",-19728),
        array("chan",-19725),
        array("chang",-19715),
        array("chao",-19540),
        array("che",-19531),
        array("chen",-19525),
        array("cheng",-19515),
        array("chi",-19500),
        array("chong",-19484),
        array("chou",-19479),
        array("chu",-19467),
        array("chuai",-19289),
        array("chuan",-19288),
        array("chuang",-19281),
        array("chui",-19275),
        array("chun",-19270),
        array("chuo",-19263),
        array("ci",-19261),
        array("cong",-19249),
        array("cou",-19243),
        array("cu",-19242),
        array("cuan",-19238),
        array("cui",-19235),
        array("cun",-19227),
        array("cuo",-19224),
        array("da",-19218),
        array("dai",-19212),
        array("dan",-19038),
        array("dang",-19023),
        array("dao",-19018),
        array("de",-19006),
        array("deng",-19003),
        array("di",-18996),
        array("dian",-18977),
        array("diao",-18961),
        array("die",-18952),
        array("ding",-18783),
        array("diu",-18774),
        array("dong",-18773),
        array("dou",-18763),
        array("du",-18756),
        array("duan",-18741),
        array("dui",-18735),
        array("dun",-18731),
        array("duo",-18722),
        array("e",-18710),
        array("en",-18697),
        array("er",-18696),
        array("fa",-18526),
        array("fan",-18518),
        array("fang",-18501),
        array("fei",-18490),
        array("fen",-18478),
        array("feng",-18463),
        array("fo",-18448),
        array("fou",-18447),
        array("fu",-18446),
        array("ga",-18239),
        array("gai",-18237),
        array("gan",-18231),
        array("gang",-18220),
        array("gao",-18211),
        array("ge",-18201),
        array("gei",-18184),
        array("gen",-18183),
        array("geng",-18181),
        array("gong",-18012),
        array("gou",-17997),

        array("gu",-17988),
        array("gua",-17970),
        array("guai",-17964),
        array("guan",-17961),
        array("guang",-17950),
        array("gui",-17947),
        array("gun",-17931),
        array("guo",-17928),
        array("ha",-17922),
        array("hai",-17759),
        array("han",-17752),
        array("hang",-17733),
        array("hao",-17730),
        array("he",-17721),
        array("hei",-17703),
        array("hen",-17701),
        array("heng",-17697),
        array("hong",-17692),
        array("hou",-17683),
        array("hu",-17676),
        array("hua",-17496),
        array("huai",-17487),
        array("huan",-17482),
        array("huang",-17468),
        array("hui",-17454),
        array("hun",-17433),
        array("huo",-17427),
        array("ji",-17417),
        array("jia",-17202),
        array("jian",-17185),
        array("jiang",-16983),
        array("jiao",-16970),
        array("jie",-16942),
        array("jin",-16915),
        array("jing",-16733),
        array("jiong",-16708),
        array("jiu",-16706),
        array("ju",-16689),
        array("juan",-16664),
        array("jue",-16657),
        array("jun",-16647),
        array("ka",-16474),
        array("kai",-16470),
        array("kan",-16465),
        array("kang",-16459),
        array("kao",-16452),
        array("ke",-16448),
        array("ken",-16433),
        array("keng",-16429),
        array("kong",-16427),
        array("kou",-16423),
        array("ku",-16419),
        array("kua",-16412),
        array("kuai",-16407),
        array("kuan",-16403),
        array("kuang",-16401),
        array("kui",-16393),
        array("kun",-16220),
        array("kuo",-16216),
        array("la",-16212),
        array("lai",-16205),
        array("lan",-16202),
        array("lang",-16187),
        array("lao",-16180),
        array("le",-16171),
        array("lei",-16169),
        array("leng",-16158),
        array("li",-16155),
        array("lia",-15959),
        array("lian",-15958),
        array("liang",-15944),
        array("liao",-15933),
        array("lie",-15920),
        array("lin",-15915),
        array("ling",-15903),
        array("liu",-15889),
        array("long",-15878),
        array("lou",-15707),
        array("lu",-15701),
        array("lv",-15681),
        array("luan",-15667),
        array("lue",-15661),
        array("lun",-15659),
        array("luo",-15652),
        array("ma",-15640),
        array("mai",-15631),
        array("man",-15625),
        array("mang",-15454),
        array("mao",-15448),
        array("me",-15436),
        array("mei",-15435),
        array("men",-15419),
        array("meng",-15416),
        array("mi",-15408),
        array("mian",-15394),
        array("miao",-15385),
        array("mie",-15377),
        array("min",-15375),
        array("ming",-15369),
        array("miu",-15363),
        array("mo",-15362),
        array("mou",-15183),
        array("mu",-15180),
        array("na",-15165),
        array("nai",-15158),
        array("nan",-15153),
        array("nang",-15150),
        array("nao",-15149),
        array("ne",-15144),
        array("nei",-15143),
        array("nen",-15141),
        array("neng",-15140),
        array("ni",-15139),
        array("nian",-15128