<?php
class ChineseSpell {
/**
* @var array $chineseSpellList 拼音编码对应表
* @access private
*/
private $chineseSpellList = array(
‘a’=>-20319,
‘ai’=>-20317,
‘an’=>-20304,
‘ang’=>-20295,
‘ao’=>-20292,
‘ba’=>-20283,
‘bai’=>-20265,
‘ban’=>-20257,
‘bang’=>-20242,
‘bao’=>-20230,
‘bei’=>-20051,
‘ben’=>-20036,
‘beng’=>-20032,
‘bi’=>-20026,
‘bian’=>-20002,
‘biao’=>-19990,
‘bie’=>-19986,
‘bin’=>-19982,
‘bing’=>-19976,
‘bo’=>-19805,
‘bu’=>-19784,
‘ca’=>-19775,
‘cai’=>-19774,
‘can’=>-19763,
‘cang’=>-19756,
‘cao’=>-19751,
‘ce’=>-19746,
‘ceng’=>-19741,
‘cha’=>-19739,
‘chai’=>-19728,
‘chan’=>-19725,
‘chang’=>-19715,
‘chao’=>-19540,
‘che’=>-19531,
‘chen’=>-19525,
‘cheng’=>-19515,
‘chi’=>-19500,
‘chong’=>-19484,
‘chou’=>-19479,
‘chu’=>-19467,
‘chuai’=>-19289,
‘chuan’=>-19288,
‘chuang’=>-19281,
‘chui’=>-19275,
‘chun’=>-19270,
‘chuo’=>-19263,
‘ci’=>-19261,
‘cong’=>-19249,
‘cou’=>-19243,
‘cu’=>-19242,
‘cuan’=>-19238,
‘cui’=>-19235,
‘cun’=>-19227,
‘cuo’=>-19224,
‘da’=>-19218,
‘dai’=>-19212,
‘dan’=>-19038,
‘dang’=>-19023,
‘dao’=>-19018,
‘de’=>-19006,
‘deng’=>-19003,
‘di’=>-18996,
‘dian’=>-18977,
‘diao’=>-18961,
‘die’=>-18952,
‘ding’=>-18783,
‘diu’=>-18774,
‘dong’=>-18773,
‘dou’=>-18763,
‘du’=>-18756,
‘duan’=>-18741,
‘dui’=>-18735,
‘dun’=>-18731,
‘duo’=>-18722,
‘e’=>-18710,
‘en’=>-18697,
‘er’=>-18696,
‘fa’=>-18526,
‘fan’=>-18518,
‘fang’=>-18501,
‘fei’=>-18490,
‘fen’=>-18478,
‘feng’=>-18463,
‘fo’=>-18448,
‘fou’=>-18447,
‘fu’=>-18446,
‘ga’=>-18239,
‘gai’=>-18237,
‘gan’=>-18231,
‘gang’=>-18220,
‘gao’=>-18211,
‘ge’=>-18201,
‘gei’=>-18184,
‘gen’=>-18183,
‘geng’=>-18181,
‘gong’=>-18012,
‘gou’=>-17997,
‘gu’=>-17988,
‘gua’=>-17970,
‘guai’=>-17964,
‘guan’=>-17961,
‘guang’=>-17950,
‘gui’=>-17947,
‘gun’=>-17931,
‘guo’=>-17928,
‘ha’=>-17922,
‘hai’=>-17759,
‘han’=>-17752,
‘hang’=>-17733,
‘hao’=>-17730,
‘he’=>-17721,
‘hei’=>-17703,
‘hen’=>-17701,
‘heng’=>-17697,
‘hong’=>-17692,
‘hou’=>-17683,
‘hu’=>-17676,
‘hua’=>-17496,
‘huai’=>-17487,
‘huan’=>-17482,
‘huang’=>-17468,
‘hui’=>-17454,
‘hun’=>-17433,
‘huo’=>-17427,
‘ji’=>-17417,
‘jia’=>-17202,
‘jian’=>-17185,
‘jiang’=>-16983,
‘jiao’=>-16970,
‘jie’=>-16942,
‘jin’=>-16915,
‘jing’=>-16733,
‘jiong’=>-16708,
‘jiu’=>-16706,
‘ju’=>-16689,
‘juan’=>-16664,
‘jue’=>-16657,
‘jun’=>-16647,
‘ka’=>-16474,
‘kai’=>-16470,
‘kan’=>-16465,
‘kang’=>-16459,
‘kao’=>-16452,
‘ke’=>-16448,
‘ken’=>-16433,
‘keng’=>-16429,
‘kong’=>-16427,
‘kou’=>-16423,
‘ku’=>-16419,
‘kua’=>-16412,
‘kuai’=>-16407,
‘kuan’=>-16403,
‘kuang’=>-16401,
‘kui’=>-16393,
‘kun’=>-16220,
‘kuo’=>-16216,
‘la’=>-16212,
‘lai’=>-16205,
‘lan’=>-16202,
‘lang’=>-16187,
‘lao’=>-16180,
‘le’=>-16171,
‘lei’=>-16169,
‘leng’=>-16158,
‘li’=>-16155,
‘lia’=>-15959,
‘lian’=>-15958,
‘liang’=>-15944,
‘liao’=>-15933,
‘lie’=>-15920,
‘lin’=>-15915,
‘ling’=>-15903,
‘liu’=>-15889,
‘long’=>-15878,
‘lou’=>-15707,
‘lu’=>-15701,
‘lv’=>-15681,
‘luan’=>-15667,
‘lue’=>-15661,
‘lun’=>-15659,
‘luo’=>-15652,
‘ma’=>-15640,
‘mai’=>-15631,
‘man’=>-15625,
‘mang’=>-15454,
‘mao’=>-15448,
‘me’=>-15436,
‘mei’=>-15435,
‘men’=>-15419,
‘meng’=>-15416,
‘mi’=>-15408,
‘mian’=>-15394,
‘miao’=>-15385,
‘mie’=>-15377,
‘min’=>-15375,
‘ming’=>-15369,
‘miu’=>-15363,
‘mo’=>-15362,
‘mou’=>-15183,
‘mu’=>-15180,
‘na’=>-15165,
‘nai’=>-15158,
‘nan’=>-15153,
‘nang’=>-15150,
‘nao’=>-15149,
‘ne’=>-15144,
‘nei’=>-15143,
‘nen’=>-15141,
‘neng’=>-15140,
‘ni’=>-15139,
‘nian’=>-15128,
‘niang’=>-15121,
‘niao’=>-15119,
‘nie’=>-15117,
‘nin’=>-15110,
‘ning’=>-15109,
‘niu’=>-14941,
‘nong’=>-14937,
‘nu’=>-14933,
‘nv’=>-14930,
‘nuan’=>-14929,
‘nue’=>-14928,
‘nuo’=>-14926,
‘o’=>-14922,
‘ou’=>-14921,
‘pa’=>-14914,
‘pai’=>-14908,
‘pan’=>-14902,
‘pang’=>-14894,
‘pao’=>-14889,
‘pei’=>-14882,
‘pen’=>-14873,
‘peng’=>-14871,
‘pi’=>-14857,
‘pian’=>-14678,
‘piao’=>-14674,
‘pie’=>-14670,
‘pin’=>-14668,
‘ping’=>-14663,
‘po’=>-14654,
‘pu’=>-14645,
‘qi’=>-14630,
‘qia’=>-14594,
‘qian’=>-14429,
‘qiang’=>-14407,
‘qiao’=>-14399,
‘qie’=>-14384,
‘qin’=>-14379,
‘qing’=>-14368,
‘qiong’=>-14355,
‘qiu’=>-14353,
‘qu’=>-14345,
‘quan’=>-14170,
‘que’=>-14159,
‘qun’=>-14151,
‘ran’=>-14149,
‘rang’=>-14145,
‘rao’=>-14140,
‘re’=>-14137,
‘ren’=>-14135,
‘reng’=>-14125,
‘ri’=>-14123,
‘rong’=>-14122,
‘rou’=>-14112,
‘ru’=>-14109,
‘ruan’=>-14099,
‘rui’=>-14097,
‘run’=>-14094,
‘ruo’=>-14092,
‘sa’=>-14090,
‘sai’=>-14087,
‘san’=>-14083,
‘sang’=>-13917,
‘sao’=>-13914,
‘se’=>-13910,
‘sen’=>-13907,
‘seng’=>-13906,
‘sha’=>-13905,
‘shai’=>-13896,
‘shan’=>-13894,
‘shang’=>-13878,
‘shao’=>-13870,
‘she’=>-13859,
‘shen’=>-13847,
‘sheng’=>-13831,
‘shi’=>-13658,
‘shou’=>-13611,
‘shu’=>-13601,
‘shua’=>-13406,
‘shuai’=>-13404,
‘shuan’=>-13400,
‘shuang’=>-13398,
‘shui’=>-13395,
‘shun’=>-13391,
‘shuo’=>-13387,
‘si’=>-13383,
‘song’=>-13367,
‘sou’=>-13359,
‘su’=>-13356,
‘suan’=>-13343,
‘sui’=>-13340,
‘sun’=>-13329,
‘suo’=>-13326,
‘ta’=>-13318,
‘tai’=>-13147,
‘tan’=>-13138,
‘tang’=>-13120,
‘tao’=>-13107,
‘te’=>-13096,
‘teng’=>-13095,
‘ti’=>-13091,
‘tian’=>-13076,
‘tiao’=>-13068,
‘tie’=>-13063,
‘ting’=>-13060,
‘tong’=>-12888,
‘tou’=>-12875,
‘tu’=>-12871,
‘tuan’=>-12860,
‘tui’=>-12858,
‘tun’=>-12852,
‘tuo’=>-12849,
‘wa’=>-12838,
‘wai’=>-12831,
‘wan’=>-12829,
‘wang’=>-12812,
‘wei’=>-12802,
‘wen’=>-12607,
‘weng’=>-12597,
‘wo’=>-12594,
‘wu’=>-12585,
‘xi’=>-12556,
‘xia’=>-12359,
‘xian’=>-12346,
‘xiang’=>-12320,
‘xiao’=>-12300,
‘xie’=>-12120,
‘xin’=>-12099,
‘xing’=>-12089,
‘xiong’=>-12074,
‘xiu’=>-12067,
‘xu’=>-12058,
‘xuan’=>-12039,
‘xue’=>-11867,
‘xun’=>-11861,
‘ya’=>-11847,
‘yan’=>-11831,
‘yang’=>-11798,
‘yao’=>-11781,
‘ye’=>-11604,
‘yi’=>-11589,
‘yin’=>-11536,
‘ying’=>-11358,
‘yo’=>-11340,
‘yong’=>-11339,
‘you’=>-11324,
‘yu’=>-11303,
‘yuan’=>-11097,
‘yue’=>-11077,
‘yun’=>-11067,
‘za’=>-11055,
‘zai’=>-11052,
‘zan’=>-11045,
‘zang’=>-11041,
‘zao’=>-11038,
‘ze’=>-11024,
‘zei’=>-11020,
‘zen’=>-11019,
‘zeng’=>-11018,
‘zha’=>-11014,
‘zhai’=>-10838,
‘zhan’=>-10832,
‘zhang’=>-10815,
‘zhao’=>-10800,
‘zhe’=>-10790,
‘zhen’=>-10780,
‘zheng’=>-10764,
‘zhi’=>-10587,
‘zhong’=>-10544,
‘zhou’=>-10533,
‘zhu’=>-10519,
‘zhua’=>-10331,
‘zhuai’=>-10329,
‘zhuan’=>-10328,
‘zhuang’=>-10322,
‘zhui’=>-10315,
‘zhun’=>-10309,
‘zhuo’=>-10307,
‘zi’=>-10296,
‘zong’=>-10281,
‘zou’=>-10274,
‘zu’=>-10270,
‘zuan’=>-10262,
‘zui’=>-10260,
‘zun’=>-10256,
‘zuo’=>-10254
);
/**
* 取汉字所有拼音
* @param string $chinese 要转换的汉字
* @param string $delimiter 分隔符
* @param int $length 返回的长度
* @return string
*/
public function getFullSpell($chinese, $delimiter = ‘ ‘, $length = 0) {
$spell = $this->getChineseSpells($chinese, $delimiter);
if ($length) {
$spell = substr($spell, 0, $length);
}
return $spell;
}
/**
* 取汉字第一个拼音
* @param string $chinese 要转换的汉字
* @param int $length 返回的长度
* @return string
*/
public function getFirstSpell($chinese, $length = 0) {
$spell = $this->getChineseSpells($chinese, ‘ ‘, 1);
if ($length) {
$spell = substr($spell, 0, $length);
}
return $spell;
}
/**
* 取一个汉字码对应的拼音
* @param int $num 汉字码
* @param string $blank 空白字符
* @return string
*/
private function getChineseSpell ($num, $blank = ”) {
if ( $num>0 && $num<160 ) {
return chr($num);
} elseif ($num<-20319||$num>-10247) {
return $blank;
} else {
foreach ($this->chineseSpellList as $spell => $code) {
if ($code > $num) break;
$result = $spell;
}
return $result;
}
}
/**
* 取汉字拼音
* @param string $chinese 要转换的汉字
* @param string $delimiter 分隔符
* @param int $first 是否只返回第一个
* @return string
*/
private function getChineseSpells($chinese, $delimiter = ‘ ‘, $first=0)
{
$result = array();
for ($i=0; $i<strlen($chinese); $i++) {
$p = ord(substr($chinese,$i,1));
if ($p>160) {
$q = ord(substr($chinese,++$i,1));
$p = $p*256 + $q – 65536;
}
$result[] = $this->getChineseSpell($p);
if ($first) {
return $result[0];
}
}
return implode($delimiter, $result);
}
}
?>
标签: PHP
-
PHP生成中文拼音
-
php代码防注入事例
今天写代码的时候猛然想到是不能能够通过一个文件来处理整个网站中所有可能出现注入的地方进行防范呢?这样就能够不用在每个程序里对每个变量进行过滤,节省了时间和代码。
我们主要是从两点出发,因为我们的获取的变量一般都是通过GET或者POST方式提交过来的,那么我们只要对GET和POST过来的变量进行过滤,那么就能够达到防止注入的效果。而且我们的PHP真是非常好,已经内置了$_GET和$_POST两个数组来存储所有变量,我们要做的工作就是过滤每个变量就可以了。
下面看具体的代码:php代码:
以下为引用的内容:
/*
PHP118= 全球最大的PHP中文社群 = PHPer的网上家园
*//* Author: heiyeluren */
/* 过滤所有GET过来变量 */
foreach ($_GET as $get_key=%26gt;$get_var)
{
if (is_numeric($get_var))
if (is_numeric($get_var)) {
$get[strtolower($get_key)] = get_int($get_var);
} else {
$get[strtolower($get_key)] = get_str($get_var);
}
}/* 过滤所有POST过来的变量 */
foreach ($_POST as $post_key=%26gt;$post_var)
{
if (is_numeric($post_var)) {
$post[strtolower($post_key)] = get_int($post_var);
} else {
$post[strtolower($post_key)] = get_str($post_var);
}
}/* 过滤函数 */
//整型过滤函数
function get_int($number)
{
return intval($number);
}
//字符串型过滤函数
function get_str($string)
{
if (!get_magic_quotes_gpc()) {
return addslashes($string);
}
return $string;
}
那么我们把以上代码放到一个公共的文件里,比如security.inc.php里面,每个文件里都include一下这个文件,那么就能够给任何一个程序进行提交的所有变量进行过滤了,就达到了我们一劳永逸的效果。 -
PHP下载文件名乱码问题详解
通过把Content-Type设置为application/octet-stream,可以把动态生成的内容当作文件来下载,相信这个大家都会。那么用Content-Disposition设置下载的文件名,这个也有不少人知道吧。基本上,下载程序都是这么写的:
header(‘Content-Disposition: attachment; filename=’ . $filename);print “Hello!”;?>
这样用浏览器打开之后,就可以下载document.txt。
但是,如果$filename是UTF-8编码的,有些浏览器就无法正常处理了。比如把上面那个程序稍稍改一下:
header(‘Content-Disposition: attachment; filename=’ . $filename);print “Hello!”;?>
把程序保存成UTF-8编码再访问,IE6下载的文件名就会乱码。 FF3下下载的文件名就只有“中文”两个字。Opera 9下一切正常。
输出的header实际上是这样子:
Content-Disposition: attachment; filename=中文 文件名.txt
其实按照RFC2231的定义,多语言编码的Content-Disposition应该这么定义:Content-Disposition: attachment; filename*=”utf8”%E4%B8%AD%E6%96%87%20%E6%96%87%E4%BB%B6%E5%90%8D.txt”
即:
filename后面的等号之前要加 * filename的值用单引号分成三段,分别是字符集(utf8)、语言(空)和urlencode过的文件名。 最好加上双引号,否则文件名中空格后面的部分在Firefox中显示不出来 注意urlencode的结果与php的urlencode函数结果不太相同,php的urlencode会把空格替换成+,而这里需要替换成%20
经过试验,发现几种主流浏览器的支持情况如下:
IE6 attachment; filename=””
FF3 attachment; filename=”UTF-8文件名”
attachment; filename*=”utf8””
O9 attachment; filename=”UTF-8文件名”
Safari3(Win) 貌似不支持?上述方法都不行
这样看来,程序必须得这样写才能支持所有主流浏览器:
以下为引用的内容:
$encoded_filename = urlencode($filename);$encoded_filename = str_replace(“+”, “%20”, $encoded_filename);header(‘Content-Type: application/octet-stream’);if (preg_match(“/MSIE/”, $ua)) { header(‘Content-Disposition: attachment; filename=”‘ . $encoded_filename . ‘”‘);} else if (preg_match(“/Firefox/”, $ua)) { header(‘Content-Disposition: attachment; filename*=”utf8\’\” . $filename . ‘”‘);} else { header(‘Content-Disposition: attachment; filename=”‘ . $filename . ‘”‘);}print ‘ABC’;?>
-
Joomla! v1.5.10 Final
Joomla!是一套在国外相当知名的内容管理系统(Content Management System – CMS),它属于Portal(企业入口网站)类型,顾名思义,就是比较适合作为商业类型的网站程序.它是开源的!Joomla!是使用PHP语言加上 MySQL数据库所开发的软件系统,可以在Linux、Windows、MacOSX等各种不同的平台上执行.
Joomla!是使用PHP语言加上MySQL数据库所开发的软件系统,可以在Linux、Windows、MacOSX等各种不同的平台上执行。目前是由Open Source Matters (www.opensourcematters.org)这个开放源码组织进行开发与支持,这个组织的成员来自全世界各地,小组成员约有150人,包含了开发者、设计者、系统管理者、文件撰写者,以及超过2万名的参与会员。
官网:http://www.joomla.org
-
PHP获取网页源代码内容
php可以用几个函数来采集网页的源代码,晚上无聊写了一份查看搜索引擎收录情况的代码,只是简单写了下并没有做什么处理,把代码贴上面留日后查看。
function baidu($s,$t){
$baidu=”http://www.baidu.com/s?wd=site%3A”.$s.”&lm=”.$t;
$site=file_get_contents($baidu);
$site=iconv(“gb2312”, “UTF-8”, $site);
ereg(“相关网页(.*)篇”, $site, $count);
$count=str_replace(“相关网页”,””,$count);
$count=str_replace(“篇”,””,$count);
$count=str_replace(“约”,””,$count);
return $count[0];
}
function google($s,$t){
$google=”http://www.google.cn/search?q=site%3A”.$s.”&as_qdr=”.$t;
$site=file_get_contents($google);
$site=iconv(“gb2312”, “UTF-8”, $site);
ereg(“约有 <b>(.*)</b> 项符合”, $site, $count);
$count=str_replace(“约有 <b>”,””,$count);
$count=str_replace(“</b> 项符合”,””,$count);
return $count[0];
} -
yeswan武林三国的安装与卸载
这个论坛插件是一款WEB游戏,可以让开论坛的站长赚钱的一款插件,虽然本人没有玩这款游戏,但是WEB游戏也是一种趋势,越来越多的人会加入进来的,昨天也安装了这款插件,但是不小心输入错误API码,无奈查看yeswan.php文件(我安装的是DISCUZ),发现这款插件是有卸载命令的,并且找到了这款插件的配置文件,但是鉴于多种论坛的多种配置文件的存放我并不清楚,就只说下安装与卸载,我认为这个是通用的。
在说明文件中介绍的安装方法
安装
1.复制相应字符集的yeswan.php文件到您论坛的根目录下
2.访问安装地址:http://您的论坛地址/yeswan.php?action=install
3.正确填写并提交表单在提交的action中,其实是可以使用uninstall来进行卸载的
if($_GET[‘action’] == ‘install’ || $_GET[‘action’] == ‘uninstall’) {
if($yw_userinfo[‘isadmin’] != 1) {
exit(‘您没有权限安装/卸载此插件’);
}访问卸载地址:http://您的论坛地址/yeswan.php?action=uninstall
-
安装PHP请更新道PHP5.2.8
在前几天官方发布了5.2.7 不过紧接着就发布了5.2.8,原因是5.2.7中发现了一个严重的BUG。
08 Dec 2008, PHP 5.2.8
– Reverted bug fix #42718 that broke magic_quotes_gpc (Scott)PS:我的机器还在用5.2.6 实在是懒得更新了,不过保守估计我的版本已经是相当的新啦 哈哈
-
DEDECMS5.3正式版
新版本发布了,这次的更新是内核级的更新,论坛里面有了数据压力测试看上去效果是不错的,dede是我使用过较多的CMS系统,其开源简单可以很容易的把他变成任何类型的网站,模板的制作也非常简单,现在的采集功能似乎是每个CMS必备的了,我也因此不必在去手动更新每一篇文章,不过带来的就是被搜索引擎无情的K出去,也因为它我感觉到我在做垃圾站,可以说是又爱又恨。不过发布新版本还是挺高兴的,现在在用5.3的测试版依然在疯狂的采集,就是采集的时候时常碰到超时还是错误,导致不在自动采集,希望能在正式版中得到解决,希望这个系统越来越好吧,是国内开源程序里面比较喜欢的一款。
PS:我以前听说会出一个以3.1为基础的简洁版,不过这个并不出功能太庞大了。
-
EditPlus功能强大的文本编辑器
其实有很多文本编辑器,但是使用中这款编辑器轻便好用不自觉的就习惯的使用上了,在编写网页的时候也是不错的选择,之前也推荐过一款编辑器是国内开源的文本编辑器,最近也去它的官方社区看了看,并且在更新所以还是选择editplus使用毕竟是熟悉的,当然这款软件是需要注册的不过网上很多注册机,破解也是相当的容易。哦对了 这个似乎是韩国人写的。
它拥有无限制的Undo/Redo功能,让你不再为一步误操作而后悔不已;其强劲的英文拼字检查、自动换行、列数标记、语法高亮显示、垂直选择、搜寻功能,让你全面体验记事本所没有的超强功能;它可以同时编辑多种文件类型,轻松做到“一旦拥有,别无所求”;另外还有全屏幕浏览功能;特别值得一提的是,它的监视剪贴板的功能,能同步于剪贴板自动将文字贴进EditPlus的编辑窗口中,让你省去粘贴的步骤。
其次,EditPlus还是一个好用的(X)HTML编辑器。
在EditPlus中设计网页和编辑一个文档没什么两样。单击“File”→“New”→“HTMLPage”,就可以打开“HTML页面编辑器”窗口,使用它所提供的工具就可以直接进行网页的编辑与创作。EditPlus除了可以对你直接输入的文字用颜色标记HTMLTag(同时支持C/C++、Perl、Java)外,还内建了完整的HTML和CSS1指令功能,你甚至可以一边编辑一边“浏览”(CTRL+B)页面效果。对于习惯用记事本进行网页编辑的网友们来说,它可以帮你节省一半的网页编辑时间。
再次,EditPlus其他比较好用的功能包括:可以设置工程并进行多文件查找;代码片断;自动完成;设置标记方便跳转
本站就不提供下载地址了,网上下载地址超多,并且更新也挺快的。
-
PHP的编码问题
刚开始学PHP很容易出现乱码情况,一般是因为编码不一致导致的。碰到乱码情况主要考虑三个方面:
页面存储的编码,PHP处理数据的编码,MYSQL的数据编码。
比如页面<meta http-equiv=”Content-Type” content=”text/html; charset=UTF-8″ /> 设定了UTF-8的编码 PHP在操作数据库的时候也设置下mysql_query(“set names ‘utf8′”); 最后就是把数据库的编码设置成utf8_general_ci 统一了编码就会少很多问题。
-
优化PHP代码的40条建议
简介
英文版权归Reinhold Weber所有,中译文作者yangyang(aka davidkoree)。双语版可用于非商业传播,但须注明英文版作者、版权信息,以及中译文作者。翻译水平有限,请广大PHPer指正。
1.如果一个方法可静态化,就对它做静态声明。速率可提升至4倍。
2.echo 比 print 快。
3.使用echo的多重参数(译注:指用逗号而不是句点)代替字符串连接。
4.在执行for循环之前确定最大循环数,不要每循环一次都计算最大值。
5.注销那些不用的变量尤其是大数组,以便释放内存。
6.尽量避免使用__get,__set,__autoload。
7.require_once()代价昂贵。
8.在包含文件时使用完整路径,解析操作系统路径所需的时间会更少。
9.如果你想知道脚本开始执行(译注:即服务器端收到客户端请求)的时刻,使用$_SERVER[‘REQUEST_TIME’]要好于time()。
10.函数代替正则表达式完成相同功能。
11.str_replace函数比preg_replace函数快,但strtr函数的效率是str_replace函数的四倍。
12.如果一个字符串替换函数,可接受数组或字符作为参数,并且参数长度不太长,那么可以考虑额外写一段替换代码,使得每次传递参数是一个字符,而不是只写一行代码接受数组作为查询和替换的参数。
13.使用选择分支语句(译注:即switch case)好于使用多个if,else if语句。
14.用@屏蔽错误消息的做法非常低效。
15.打开apache的mod_deflate模块。
16.数据库连接当使用完毕时应关掉。
17.$row[‘id’]的效率是$row[id]的7倍。
18.错误消息代价昂贵。
19.尽量不要在for循环中使用函数,比如for ($x=0; $x < count($array); $x)每循环一次都会调用count()函数。
20.在方法中递增局部变量,速度是最快的。几乎与在函数中调用局部变量的速度相当。
21.递增一个全局变量要比递增一个局部变量慢2倍。
22.递增一个对象属性(如:$this->prop++)要比递增一个局部变量慢3倍。
23.递增一个未预定义的局部变量要比递增一个预定义的局部变量慢9至10倍。
24.仅定义一个局部变量而没在函数中调用它,同样会减慢速度(其程度相当于递增一个局部变量)。PHP大概会检查看是否存在全局变量。
25.方法调用看来与类中定义的方法的数量无关,因为我(在测试方法之前和之后都)添加了10个方法,但性能上没有变化。
26.派生类中的方法运行起来要快于在基类中定义的同样的方法。
27.调用带有一个参数的空函数,其花费的时间相当于执行7至8次的局部变量递增操作。类似的方法调用所花费的时间接近于15次的局部变量递增操作。
28.用单引号代替双引号来包含字符串,这样做会更快一些。因为PHP会在双引号包围的字符串中搜寻变量,单引号则不会。当然,只有当你不需要在字符串中包含变量时才可以这么做。
29.输出多个字符串时,用逗号代替句点来分隔字符串,速度更快。注意:只有echo能这么做,它是一种可以把多个字符串当作参数的“函数”(译注:PHP手册中说echo是语言结构,不是真正的函数,故把函数加上了双引号)。
30.Apache解析一个PHP脚本的时间要比解析一个静态HTML页面慢2至10倍。尽量多用静态HTML页面,少用脚本。
31.除非脚本可以缓存,否则每次调用时都会重新编译一次。引入一套PHP缓存机制通常可以提升25%至100%的性能,以免除编译开销。
32.尽量做缓存,可使用memcached。memcached是一款高性能的内存对象缓存系统,可用来加速动态Web应用程序,减轻数据库负载。对运算码 (OP code)的缓存很有用,使得脚本不必为每个请求做重新编译。
33.当操作字符串并需要检验其长度是否满足某种要求时,你想当然地会使用strlen()函数。此函数执行起来相当快,因为它不做任何计算,只返回在 zval 结构(C的内置数据结构,用于存储PHP变量)中存储的已知字符串长度。但是,由于strlen()是函数,多多少少会有些慢,因为函数调用会经过诸多步 骤,如字母小写化(译注:指函数名小写化,PHP不区分函数名大小写)、哈希查找,会跟随被调用的函数一起执行。在某些情况下,你可以使用isset() 技巧加速执行你的代码。
(举例如下)
if (strlen($foo) < 5) { echo “Foo is too short”$$ }
(与下面的技巧做比较)
if (!isset($foo{5})) { echo “Foo is too short”$$ }调用isset()恰巧比strlen()快,因为与后者不同的是,isset()作为一种语言结构,意味着它的执行不需要函数查找和字母小写化。也就是说,实际上在检验字符串长度的顶层代码中你没有花太多开销。
34.当执行变量$i的递增或递减时,$i++会比++$i慢一些。这种差异是PHP特有的,并不适用于其他语言,所以请不要修改你的C或Java代码并 指望它们能立即变快,没用的。++$i更快是因为它只需要3条指令(opcodes),$i++则需要4条指令。后置递增实际上会产生一个临时变量,这个 临时变量随后被递增。而前置递增直接在原值上递增。这是最优化处理的一种,正如Zend的PHP优化器所作的那样。牢记这个优化处理不失为一个好主意,因为并不是所有的指令优化器都会做同样的优化处理,并且存在大量没有装配指令优化器的互联网服务提供商(ISPs)和服务器。
35.并不是事必面向对象(OOP),面向对象往往开销很大,每个方法和对象调用都会消耗很多内存。
36.并非要用类实现所有的数据结构,数组也很有用。
37.不要把方法细分得过多,仔细想想你真正打算重用的是哪些代码?
38.当你需要时,你总能把代码分解成方法。
39.尽量采用大量的PHP内置函数。
40.如果在代码中存在大量耗时的函数,你可以考虑用C扩展的方式实现它们。
41.评估检验(profile)你的代码。检验器会告诉你,代码的哪些部分消耗了多少时间。Xdebug调试器包含了检验程序,评估检验总体上可以显示出代码的瓶颈。
42.mod_zip可作为Apache模块,用来即时压缩你的数据,并可让数据传输量降低80%。
-
PHP与MYSQL数据库连接语句
PHP与MYSQL数据库连接语句
mysql_connect(“localhost”, “username”, “password”)
数据库选择
mysql_select_db(“test”)
-
用PHP去读取excel文件数据
看了下这方面的资料想要去读取应该是没问题的,不过之前都没有接触过这种方式的读取,找到一点资料但是帮助不大,函数文件很大没有能看的明白,不过用它去读数据倒是可以了,会生成一个二维数组。
http://sourceforge.net/projects/phpexcelreader 一个找到的程序,可以尝试一下了。