PHP里8个鲜为人知的安全函数分析


Posted in PHP onDecember 09, 2014

本文实例讲述了PHP里8个鲜为人知的安全函数。分享给大家供大家参考。具体分析如下:

安全是编程非常重要的一个方面。在任何一种编程语言中,都提供了许多的函数或者模块来确保程序的安全性。在现代网站应用中,经常要获取来自世界各地用户的输入,但是,我们都知道“永远不能相信那些用户输入的数据”。所以在各种的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实体<(<),输入>就被转为实体>.

4. htmlspecialchars()

在HTML中,一些特定字符有特殊的含义,如果要保持字符原来的含义,就应该转换为HTML实体。这个函数会返回转换后的字符串,例如'&' (ampersand) 转为'&'

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

The translations performed are:
 '&' (ampersand) becomes '&'
 '”' (double quote) becomes '"' when ENT_NOQUOTES is not set.
 “'” (single quote) becomes ''' (or ') only when ENT_QUOTES is set.
 '<' (less than) becomes '<'
 '>' (greater than) becomes '>'

5. strip_tags()

这个函数可以去除字符串中所有的HTML,JavaScript和PHP标签,当然你也可以通过设置该函数的第二个参数,让一些特定的标签出现。

6. md5()

从安全的角度来说,一些开发者在数据库中存储简单的密码的行为并不值得推荐。md5()函数可以产生给定字符串的32个字符的md5散列,而且这个过程不可逆,即你不能从md5()的结果得到原始字符串。
现在这个函数并不被认为是安全的,因为开源的数据库可以反向检查一个散列值的明文。你可以在这里找到一个MD5散列数据库列表

7. sha1()

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

8. intval()

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

此处附上英文原文地址:http://www.pixelstech.net/article/1300722997-Useful-functions-to-provide-secure-PHP-application

希望本文所述对大家的PHP程序设计有所帮助。

PHP 相关文章推荐
PHP 和 XML: 使用expat函数(一)
Oct 09 PHP
比较时间段一与时间段二是否有交集的php函数
May 31 PHP
php基础教程 php内置函数实例教程
Aug 21 PHP
php删除与复制文件夹及其文件夹下所有文件的实现代码
Jan 23 PHP
用php随机生成福彩双色球号码的2种方法
Feb 04 PHP
深入php socket的讲解与实例分析
Jun 13 PHP
php网站地图生成类示例
Jan 13 PHP
简单了解PHP编程中数组的指针的使用
Nov 30 PHP
PHP实现图片不变型裁剪及图片按比例裁剪的方法
Jan 14 PHP
php版本CKEditor 4和CKFinder安装及配置方法图文教程
Jun 05 PHP
PHP进阶学习之类的自动加载机制原理分析
Jun 18 PHP
php常用的工具开发整理
Sep 26 PHP
php实现MySQL数据库备份与还原类实例
Dec 09 #PHP
两个php日期控制类实例
Dec 09 #PHP
php中Ctype函数用法详解
Dec 09 #PHP
完美解决thinkphp验证码出错无法显示的方法
Dec 09 #PHP
thinkphp缓存技术详解
Dec 09 #PHP
ThinkPHP中url隐藏入口文件后接收alipay传值的方法
Dec 09 #PHP
php生成shtml类用法实例
Dec 09 #PHP
You might like
一个ftp类(ini.php)
2006/10/09 PHP
检查用户名是否已在mysql中存在的php写法
2014/01/20 PHP
php文件服务实现虚拟挂载其他目录示例
2014/04/17 PHP
详解AngularJS中的表达式使用
2015/06/16 Javascript
jquery实现鼠标滑过显示二级下拉菜单效果
2015/08/24 Javascript
jQuery采用连缀写法实现的折叠菜单效果
2015/09/18 Javascript
jquery实现倒计时效果
2015/12/14 Javascript
JavaScript数组去重的几种方法效率测试
2016/10/23 Javascript
jQuery实现拖拽可编辑模块功能代码
2017/01/12 Javascript
vue实现多条件和模糊搜索功能
2019/05/28 Javascript
详解JavaScript作用域 闭包
2020/07/29 Javascript
[01:56]无止竞 再出发——中国军团出征2017年DOTA2国际邀请赛
2017/07/05 DOTA
[31:55]完美世界DOTA2联赛循环赛 IO vs GXR BO2第一场 11.04
2020/11/05 DOTA
详细解析Python当中的数据类型和变量
2015/04/25 Python
玩转python爬虫之cookie使用方法
2016/02/17 Python
关于python的bottle框架跨域请求报错问题的处理方法
2017/03/19 Python
python 打印直角三角形,等边三角形,菱形,正方形的代码
2017/11/21 Python
利用python将pdf输出为txt的实例讲解
2018/04/23 Python
Python3用tkinter和PIL实现看图工具
2018/06/21 Python
解决在pycharm中显示额外的 figure 窗口问题
2019/01/15 Python
python 协程中的迭代器,生成器原理及应用实例详解
2019/10/28 Python
Python3.7基于hashlib和Crypto实现加签验签功能(实例代码)
2019/12/04 Python
Python抓新型冠状病毒肺炎疫情数据并绘制全国疫情分布的代码实例
2020/02/05 Python
移动端HTML5 input常见问题(小结)
2020/09/28 HTML / CSS
yy结婚证婚词
2014/01/10 职场文书
交通事故私了协议书
2014/04/16 职场文书
《秋游》教学反思
2014/04/24 职场文书
小学生安全演讲稿
2014/04/25 职场文书
公益广告标语
2014/06/19 职场文书
项目建议书
2015/02/04 职场文书
领导干部失职检讨书
2015/05/05 职场文书
2015年高一班主任工作总结
2015/05/13 职场文书
初婚初育证明范本
2015/06/18 职场文书
Web前端:CSS最强总结 附详细代码
2021/03/31 HTML / CSS
详解用Python把PDF转为Word方法总结
2021/04/27 Python
SQLServer中JSON文档型数据的查询问题解决
2021/06/27 SQL Server