php插入含有特殊符号数据的处理方法

转载  更新时间:2016年11月24日 11:57:21   投稿:daisy   我要评论

当我们需要利用php插入含有特殊符号数据的时候,会发现数据无法正常插入,那么这个时候该如何解决呢?最近在工作就遇到了这个问题,于是通过查找资料也得以解决了,现在将处理的方法分享给大家,有需要的朋友们可以参考借鉴,下面来一起学习学习吧。

发现问题

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

mysql_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()

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

相关文章

  • PHP 采集心得技巧

    PHP 采集心得技巧

    今天给大家共享一下我的采集代码! 思路: 采集程序的思路很简单大体可以分为以下几个步骤
    2009-05-05
  • PHP实现ASCII码与字符串相互转换的方法

    PHP实现ASCII码与字符串相互转换的方法

    这篇文章主要介绍了PHP实现ASCII码与字符串相互转换的方法,涉及php字符串的遍历、替换、编码转换等相关操作技巧,需要的朋友可以参考下
    2017-04-04
  • php中call_user_func函数使用注意事项

    php中call_user_func函数使用注意事项

    这篇文章主要介绍了php中call_user_func函数使用注意事项,较为详细的讲述了call_user_func函数的用法实例与注意事项,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-11-11
  • php数组函数序列之each() - 获取数组当前内部指针所指向元素的键名和键值,并将指针移到下一位

    php数组函数序列之each() - 获取数组当前内部指针所指向元素的键

    each() 函数生成一个由数组当前内部指针所指向的元素的键名和键值组成的数组,并把内部指针向前移动。返回的数组中包括的四个元素:键名为 0,1,key 和 value。单元 0 和 key 包含有数组单元的键名,1 和 value 包含有数据
    2011-10-10
  • php实现的简易扫雷游戏实例

    php实现的简易扫雷游戏实例

    这篇文章主要介绍了php实现的简易扫雷游戏,涉及php字符串及流程控制的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • 分享下php5类中三种数据类型的区别

    分享下php5类中三种数据类型的区别

    这篇文章主要介绍了php5类中三种数据类型的区别,需要的朋友可以参考下
    2015-01-01
  • php中通过虚代理实现延迟加载的实现代码

    php中通过虚代理实现延迟加载的实现代码

    基本原理是通过一个虚代理(Virtual Proxy)做占位符,一旦访问代理对象的某成员(方法或属性),加载就被触发。
    2011-06-06
  • php生成唯一数字id的方法汇总

    php生成唯一数字id的方法汇总

    我们在平时的项目中,经常会遇到要使用php生成唯一数字id的环境,网上查了很多资料,其实还是有一定的可能性重复的,所以今天在这里分享下,个人最近研究这个问题的所得。
    2015-11-11
  • 详解在PHP的Yii框架中使用行为Behaviors的方法

    详解在PHP的Yii框架中使用行为Behaviors的方法

    这篇文章主要介绍了在PHP的Yii框架中使用行为Behaviors的方法,包括行为的绑定与解除等操作讲解,需要的朋友可以参考下
    2016-03-03
  • php遍历目录方法小结

    php遍历目录方法小结

    这篇文章主要介绍了php遍历目录方法,实例总结了常用的两种实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03

最新评论