8个与安全相关的PHP函数

安全问题是编程语言中须要考虑的重要部分,几乎在任何一种实际的语言中都会提供一些函数,模块,或其它确保安全的功能。在现代互联网中,咱们常常要 从世界各地的用户中得到输入数据。可是,咱们都知道“永远不能相信那些用户输入的数据”。因此在各类的Web开发语言中,都会提供保证用户输入数据安全的 函数。今天,咱们就来看一看做为最著名的开源语言PHP中提供的这样的函数。php

       在PHP中,有些很是有用而且方便的函数,它们能够帮助你的网站防止出现像SQL注入***,XSS***等问题。咱们看看这些在PHP中能够保证项目安全的函数,下面列出的这些函数只是我发现的对你项目有帮助的,可能会不全。
 html

20141031032449362.jpg


 

1. mysql_real_escape_string()mysql

       这个函数对于在PHP中防止SQL注入***颇有帮助,它对特殊的字符,像单引号和双引号,加上了“反斜杠”,确保用户的输入在用它去查询之前已是安全的了。但你要注意你是在链接着数据库的状况下使用这个函数。算法

       但如今mysql_real_escape_string()这个函数基本不用了,全部新的应用开发都应该使用像PDO这样的库对数据库进行操做,也就是说,咱们可使用现成的语句防止SQL注入***。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(),由于这样会致使 双层转义。你能够经过PHP中get_magic_quotes_gpc()函数检查这个变量的值。编程

3. htmlentities()安全

       这个函数对过滤用户输入数据很是有用,它能够把字符转换为 HTML 实体。好比,当用户输入字符“<”时,就会被该函数转化为HTML实体<,所以防止了XSS和SQL注入***。app

4. htmlspecialchars()编程语言

       HTML中的一些字符有着特殊的含义,若是要体现这样的含义,就要被转换为HTML实体,这个函数会返回转换后的字符串,好比,‘&’amp会转为‘&’。

5. strip_tags()

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

6. md5()

       一些开发者存储的密码很是简单,这从安全的角度上看是很差的,md5()函数能够产生给定字符串的32个字符的md5散列,并且这个过程不可逆,即你不能从md5()的结果获得原始字符串。
 
7. sha1()

       这个函数和上面的md5()类似,可是它使用了不一样的算法,产生的是40个字符的SHA-1散列(md5产生的是32个字符的散列)。

8. intval()

       不要笑,我知道这不是一个和安全相关的函数,它是在将变量转成整数类型。可是,你能够用这个函数让你的PHP代码更安全,特别是当你在解析id,年龄这样的数据时。




原文:http://www.pixelstech.net/article/1300722997-Useful-functions-to-provide-secure-PHP-application
译文:http://www.php100.com/html/it/focus/2014/1031/7679.html(翻译:PHP100_Zeroing)

相关文章
相关标签/搜索