php中字符处理注意的问题(1)

1.  in_array()函数
$zero = "0";
$za = array("00");

if(in_array($zero, $za, true)){
	echo 'in';
}else{
	echo 'not in';
}

这段代码应该输出什么?答案是in,而不是not in。
然后测试一下这个:
$zero = "0";
$za = array("00");
if("0" == "00"){
	echo '0 == 00';
}

返回'0'=='00'。
所以以后要注意:对于字符串不是说in,就表示那个字符在array里面。

2.  strtolower()函数
我在这里谈过: http://www.iteye.com/topic/297460,我的解决方式是:
urldecode(strtolower(urlendoce($str)));


3.  trim()
如果面对的是英文字符,那么trim()应该就满足了,但是对于中文字符,就应该重写以trim掉全角的空格:
function cntrim($value){
	return trim(ereg_replace("^( )*|( )*$","", $value));
}



4.  empty():
这个就有点像上面那个in_array()了,如果你要判断一个textarea里面是否有值,不能光使用empty,因为'0'字符串也会返回empty(但奇怪的是'00'就不会返回empty),重写以应对这种情况:
function non_szero_empty($value){
	return empty($value) && $value != '0';
}


5.  htmlentities():
与strtolower()类似,htmlentities也会出现一些转义gbk字符的问题,以致出现乱码。索性这样替换:
function _myhtmlentities($value){
		//$value = preg_replace('/&amp;((#(\d{3,5}|x[a-fA-F0-9]{4})|[a-zA-Z][a-z0-9]{2,5});)/', '&\\1', str_replace(array('&', '"', '<', '>'), array('&amp;', '&quot;', '&lt;', '&gt;'), $value));
		$value = str_replace(array('&', '"', '<', '>'), array('&amp;', '&quot;', '&lt;', '&gt;'), $value);
        return $value;
	}

不过现在还在疑惑为什么htmlentities会出现乱码,这样改为什么又可行。计划有时间看源代码一探究竟。

你可能感兴趣的:(java,PHP)