原文:Useful functions to provide secure PHP application

译文:实用的PHP安全函数

译者:dwqs

安全是编程很重要的一个方面。在不论什么一种编程语言中,都提供了很多的函数或者模块来确保程序的安全性。在现代站点应用中,常常要获取来自世界各地用户的输入,可是。我们都知道“永远不能相信那些用户输入的数据”。所以在各种的Web开发语言中,都会提供保证用户输入数据安全的函数。今天,我们就来看看,在著名的开源语言PHP中有哪些实用的安全函数。

在PHP中,有些非常实用的函数开源非常方便的防止你的站点遭受各种攻击。比如SQL注入攻击,XSS(Cross Site Scripting:跨站脚本)攻击等。一起看看PHP中经常使用的、能够确保项目安全的函数。注意。这并非完整的列表。是我认为对于你的i项目非常有的一些函数。

1. mysql_real_escape_string()

这个函数在PHP中防止SQL注入攻击时很实用。这个函数会对一些比如单引號、双引號、反斜杠等特殊字符加入一个反斜杠以确保在查询这些数据之前,用户提供的输入是干净的。但要注意。你是在连接数据库的前提下使用这个函数。

可是如今已经不推荐使用mysql_real_escape_string()了,全部新的应用应该使用像PDO一样的函数库运行数据库操作,也就是说。我们能够使用现成的语句防止SQL注入攻击。

2. addslashes()

这个函数的原理跟mysql_real_escape_string()相似。可是当在php.ini文件里,“magic_quotes_gpc“的值是“on”的时候,就不要使用这个函数。magic_quotes_gpc 的默认值是on。对全部的 GET、POST 和 COOKIE 数据自己主动执行 addslashes()。不要对已经被 magic_quotes_gpc 转义过的字符串使用 addslashes()。由于这样会导致双层转义。你能够使用get_magic_quotes_gpc()函数来确定它是否开启。

3. htmlentities()

这个函数对于过滤用户输入的数据很实用。

它会将一些特殊字符转换为HTML实体。比如,用户输入<时,就会被该函数转化为HTML实体<(&lt)。输入>就被转为实体&gt.(HTML实体对比表:http://www.w3school.com.cn/html/html_entities.asp)。能够防止XSS和SQL注入攻击。

4. htmlspecialchars()

在HTML中。一些特定字符有特殊的含义,假设要保持字符原来的含义,就应该转换为HTML实体。这个函数会返回转换后的字符串,比如‘&’ (ampersand) 转为’&amp‘(ps:请參照第三点中的实体对比表链接)

ps:此处原文有误(见评论),在此很感谢瑾瑜提出。现已更正,另外附上此函数常见的转换字符:

The translations performed are:

  • ‘&’ (ampersand) becomes ‘&amp;’
  • ‘”‘ (double quote) becomes ‘&quot;’ when
    ENT_NOQUOTES is not set.
  • “‘” (single quote) becomes ‘'’ (or &apos;) only when
    ENT_QUOTES is set.
  • ‘<’ (less than) becomes ‘&lt;’
  • ‘>’ (greater than) becomes ‘&gt;’

5. strip_tags()

这个函数能够去除字符串中全部的HTML,JavaScript和PHP标签。当然你也能够通过设置该函数的第二个參数。让一些特定的标签出现。

6. md5()

从安全的角度来说。一些开发人员在数据库中存储简单的password的行为并不值得推荐。md5()函数能够产生给定字符串的32个字符的md5散列。并且这个过程不可逆,即你不能从md5()的结果得到原始字符串。

如今这个函数并不被觉得是安全的,由于开源的数据库能够反向检查一个散列值的明文。

你能够在这里找到一个MD5散列数据库列表

7. sha1()

这个函数与md5()类似,可是它使用了不同的算法来产生40个字符的SHA-1散列(md5产生的是32个字符的散列)。也不要把绝对安全寄托在这个函数上,否则会有意想不到的结果。

8. intval()

先别笑,我知道这个函数和安全没什么关系。intval()函数是将变量转成整数类型,你能够用这个函数让你的PHP代码更安全,特别是当你在解析id,年龄这种数据时。

下一篇:纯CSS制作冒泡提示框

8个非常实用的PHP安全函数,你知道几个?的更多相关文章

  1. 非常实用的PHP常用函数汇总

    这篇文章主要介绍了非常实用的PHP常用函数,汇总了加密解密.字符串操作.文件操作.SQL注入等函数的实例与用法说明,在PHP项目开发中非常具有实用价值,需要的朋友可以参考下 本文实例总结了一些在php ...

  2. 简单实用的php分页函数代码

    一个简单实用的php分页函数,分页导航中可以默认为空,在函数内部再设置本页URL. 代码: <?php /** * 分页 * @category 功能 * @param $totle:信息总数 ...

  3. phpcms 的实用相关接口,函数,调用方法

    常用函数 , 打开include/global.func.php,下面存放一些公共函数view plaincopy to clipboardprint? strip_tags() 调用内容过滤html ...

  4. 分享几个实用的jquery工具函数

    1.$.browser对象属性 属性列表 说明  webkit webkit相关浏览器则返回true,否则返回false,如google,傲游.  mozilla mozilla相关浏览器则返回tru ...

  5. 分享一个实用任意路数PWM函数

    一.什么是PWM? 1.科普一下什么是PWM,嘿嘿,莫闲啰嗦,好好看看,可能大多数人听过,但可能没详细了解过,至此不妨花费几分钟,详细了解哈,PWM中文译名为:脉冲宽度调制,即控制电路在输出频率不变的 ...

  6. 两个很实用很方便的函数核心及用法{(lower_bound)+(max_element))~~

    (1)            关于 lower_bound(a,a+n,x)-a的用法:                                                求x在数组a中的 ...

  7. mysql中比较实用的几个函数

    1.曾有这样的需求: 可以使用如下函数: 语法:FIND_IN_SET(str,strlist). 定义: 1. 假如字符串str在由N子链组成的字符串列表strlist中,则返回值的范围在1到N之间 ...

  8. Pyhton实用的format()格式化函数

    Python2.6 开始,新增了一种格式化字符串的函数 str.format(),它增强了字符串格式化的功能. 基本语法是通过 {} 和 : 来代替以前的 % . format 函数可以接受不限个参数 ...

  9. R语言-实用数据对象处理函数

    length(object) 显示对象中元素/成分的数量 dim(object) 显示某个对象的维度 str(object) 显示某个对象的结构 class(object) 显示某个对象的类或类型 m ...

随机推荐

  1. 在MyEclipse中配置Weblogic10服务器

    MyEclipse中配置Weblogic10服务器 在MyEclipse中配置Weblogic10服务器也是很简单,现在将过程分享给有需要的人. 1.在下方的Server选项卡中,鼠标右键选择“Con ...

  2. vb sendmessage 详解2

    首先我们了解一下Windows的消息机制.Windows是一个消息驱动式系统,Windows消息提供应用程序与应用程序之间,应用程序与Windows系统之间进行通信的手段.举个例子,打开记事本程序,该 ...

  3. MVC下的DAO接口类和SERVICE接口类区别?

    简单理解: DAO数据库访问对象 实现连接数据库 修改.添加等细节 service服务层 面向功能 把一个整个服务 细化 调用DAO其实service其中都是一些方法 去调用DAO 甚至方法名都和DA ...

  4. Java的代理模式(通过公共接口实现)

    代理模式的一种常见的实现方案是,定义一个接口或抽象类,并派生出目标子类,和代理子类.我们要操作的是目标子类里的方法,而很多时候,我们需要为目录子类中的方法增加额外的处理,如果增加日志功能.条件判断等, ...

  5. MHDD修复硬盘坏道

    2种修复的方法,本人已经尝试过,非常管用! 1.先按SHIFT+F3扫描硬盘连接并选择,按F4键,先用一般模式扫一遍,再用高级模式扫一变,具体方法是选择LBA模式,remap项OFF,Loop the ...

  6. ubuntu中设置xampp开机启动

    sudo ln -s /opt/lampp/lampp /etc/init.d/lampp sudo update-rc.d -f lampp defaults

  7. 使用autoconfig

    1. 增加maven 依赖 <properties> <maven.compiler.target>1.8</maven.compiler.target> < ...

  8. doGet和doPost区别

    1,form运行方式 当form框里面的method为get时,执行doGet方法当form框里面的method为post时,执行doPost方法 2,生成方式 get方式有四种:1)直接在URL地址 ...

  9. HDUOJ----1170Milk

    Milk Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  10. DataSnap对象传递

    比较简单的方法: 1.引用DBXJSON,  DBXJSONReflect 假设有一个类: type TKid = class FirstName: String; LastName: String; ...