php怎么插入含有特殊符号的数据
admin
2023-06-14 01:21:57
0

问题:

当我们在向mysql写入数据时,如果数据中有特殊字符就会出现数据无法正常入库的情况,比如:

1mysql_query(”update table set `name`='make's'”);

而这个时候一般就是使用addslashes()这个函数来转义数据中的特殊字符

处理方法

PHP为了安全性,所以引入了个magic_quotes_gpc = On的功能,可以不需要做任何处理就能直接把单引号插入数据库中,那么对于Off时,则需要考虑单引号的问题了,而不是一味地信任运行环境。

magic_quotes_gpc = On时,使用了addslashes()处理后的数据在数据库中将以\'形式保存,如果此时直接输出的话,就会发现比自己期待的内容多了个\,因此stripslashes()出场了,它能把\去掉(区别于str_replace(”\”, “”,$Str))。

magic_quotes_gpc = Off时,使用了addslashes()处理后的数据在数据库中将以'形式保存,没有上面说的有\的问题,addslashes()起到插入数据不出错的作用,如果此时直接输出的话,数据正常。不需要再用stripslashes() 。

addslashes()stripslashes()正好是相反的,直接记忆:addslashes()加个\,stripslashes()去个\

那么什么时候用呢?

简单说:

magic_quotes_gpc = On时,系统会自动处理单引号等问题,用不用addslashes()stripslashes()都没关系,但是如果添加数据时用了addslashes() , 那么显示数据时必须要stripslashes()

magic_quotes_gpc = Off时,系统不会处理单引号等问题,所以插入数据时必须要使用addslashes() ,显示数据时则不需要使用stripslashes() 

既然有了分析,做程序时要怎么办呢?根据以上两种情况,可得:

不管magic_quotes_gpc是On还是Off,咱添加数据时都用addslashes() ,当On时,必须使用stripslashes(),Off时则不能用stripslashes() 

相关内容

热门资讯

伊朗最高领袖称美国在中东将不再... △伊朗最高领袖穆杰塔巴·哈梅内伊(资料图)据伊朗方面5月26日消息,伊朗最高领袖穆杰塔巴·哈梅内伊当...
韩国首尔一高架桥拆除现场发生坍... 据韩联社报道,当地时间5月26日下午2时32分许,韩国首尔市内一座高架桥拆除现场发生坍塌事故,已造成...
中国反超,日本再降一位 【文/观察者网 阮佳琪】据彭博社26日报道,2025年日本对外净资产虽创下历史新高,但被中国反超,排...
家里就一个空调一开就跳闸是什么... 原因可能是供电异常引起的跳闸,这种情况需要检查同电源上的其他电器是否出现故障导致供电异常,排除到故障...
轩逸空调结冰怎么解决 轩逸空调结冰的原因有很多种,但主要是由于空调内部温度和湿度不协调所致。这种情况发生后,空调会发出噪音...
一开灯就砰的一声跳闸 一开灯就砰的一声跳闸,可能是以下原因导致的:1. 灯具短路:灯具内部线路或元件出现短路,导致电流瞬间...
honyar灯罩怎么取下来 要取下 Honyar 灯罩,通常可以按照以下步骤进行操作:1. 关闭电源:确保灯具处于关闭状态,以避...
冰箱圆形保护器如何用万用表测量... 冰箱圆形保护器如何用万用表测量好坏可以用过载保护器检测,正常温度过载保护器是接通状态,测量电阻阻值为...
原创 电... 中国 “逐日工程” 近期取得重大进展,突破空间太阳能电站与微波无线传能的多项关键技术,自主研制的一对...
原创 种... 你以为小红书只能种草。 小红书却想为你种“同事”。 24日,小红书科技薯发布公告称,小红书笔记已开...