草根站长论坛's Archiver

mxmin216 发表于 2008-7-31 16:56

PHP中addcslashes函数与stripcslashes的用法

PHP中addcslashes函数与stripcslashes的用法今天在写一个网站的英文版时,写完后填加英文资料,我随便填写时一点问题没有,但每当填加指定的内容时却填加不上,也不报错,我查看了数据库,发现这个字段用的是“TEXT”数据数型,我以为是内容过长的原因,于是我把数据类型改成了“longtext”,但提交时发现还是出现同样的问题。*E#g@q*e{
后来请教同事,同事发现在是英文中带标点“'”的原因,MySQL执行到此处后自动认为语句结束,所以才填加不上。既然找出来了问题那就得找出对应的解决方法,那就是在文本内容中的“'”前全部加上转义字符“\”,正好PHP中提供了自动在字符串中加入或去除转义字符的函数addcslashes和stripcslashes,于是加上测试后,果然问题解决!由此可见,我平日写程序时不够严禁,总是会忽略这样那样的细节问题,如果被HACKER发现这些问题加一利用,网站基本就OVER了,所以大家一定要引以为戒,不要和我犯同样的错误哦。[g pI3^ wr
下面简单介绍这两个函数的用法:
| u ^%[;N4J string addcslashes(string str,string charlist):第1个参数str为待失物原始字符串,第2个参数charlist说明需要在原始串的哪些字符前加上字符“\”。
"{niF"g-?;J+XA0uwY string stripcslashes(string str):去掉字符串中的“\”。
u L.G,b G$WKS-g 例:
3g+Ky%p(v$Q^[r <?phpv3l s)u2R.f.e1r
$sql = 'update book set bookname='let's go' where bookid=1';
7hPE2}w1] |'~ echo $sql.'<br>';
MyF!`b4]~f J $new_sql = addcslashes($sql,''');
D4k bF@1X&R echo $new_sql.'<br>'; //update book set bookname=\'let\'s go\' where bookid=1Uhh.`/[wn
$new_sql_01 = stripcslashes($new_sql);
Mi"yQ+K~2xc3A echo $new_sql_01;  //update book set bookname='let's go' where bookid=1 {c/n?L.{ ~$fR!`1~*q
?>$R8DEe-P+`Y bf
中国数据([url=http://www.zgsj.com]www.zgsj.com[/url])网站建设技术力量雄厚,价格优惠,售后服务有保障,自助建站只需288元,送域名和空间。联系qq:302773012     小马

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.