php几个关于安全的函数

1. mysql_real_escape_string()php

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

       但如今mysql_real_escape_string()这个函数基本不用了,全部新的应用开发都应该使用像PDO这样的库对数据库进行操做,也就是说,咱们可使用现成的语句防止SQL注入攻击。mysql

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()函数检查这个变量的值。sql

3. htmlentities()数据库

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

4. htmlspecialchars()函数

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

5. strip_tags()ip

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

6. md5()

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

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

8. intval()

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

相关文章
相关标签/搜索