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,年龄这样的数据时。