8个非常实用的PHP安全函数,你知道几个?
原文: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实体<(<)。输入>就被转为实体>.(HTML实体对比表:http://www.w3school.com.cn/html/html_entities.asp)。能够防止XSS和SQL注入攻击。
4. htmlspecialchars()
在HTML中。一些特定字符有特殊的含义,假设要保持字符原来的含义,就应该转换为HTML实体。这个函数会返回转换后的字符串,比如‘&’ (ampersand) 转为’&‘(ps:请參照第三点中的实体对比表链接)
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()
从安全的角度来说。一些开发人员在数据库中存储简单的password的行为并不值得推荐。md5()函数能够产生给定字符串的32个字符的md5散列。并且这个过程不可逆,即你不能从md5()的结果得到原始字符串。
如今这个函数并不被觉得是安全的,由于开源的数据库能够反向检查一个散列值的明文。
你能够在这里找到一个MD5散列数据库列表
7. sha1()
这个函数与md5()类似,可是它使用了不同的算法来产生40个字符的SHA-1散列(md5产生的是32个字符的散列)。也不要把绝对安全寄托在这个函数上,否则会有意想不到的结果。
8. intval()
先别笑,我知道这个函数和安全没什么关系。intval()函数是将变量转成整数类型,你能够用这个函数让你的PHP代码更安全,特别是当你在解析id,年龄这种数据时。
下一篇:纯CSS制作冒泡提示框
8个非常实用的PHP安全函数,你知道几个?的更多相关文章
- 非常实用的PHP常用函数汇总
这篇文章主要介绍了非常实用的PHP常用函数,汇总了加密解密.字符串操作.文件操作.SQL注入等函数的实例与用法说明,在PHP项目开发中非常具有实用价值,需要的朋友可以参考下 本文实例总结了一些在php ...
- 简单实用的php分页函数代码
一个简单实用的php分页函数,分页导航中可以默认为空,在函数内部再设置本页URL. 代码: <?php /** * 分页 * @category 功能 * @param $totle:信息总数 ...
- phpcms 的实用相关接口,函数,调用方法
常用函数 , 打开include/global.func.php,下面存放一些公共函数view plaincopy to clipboardprint? strip_tags() 调用内容过滤html ...
- 分享几个实用的jquery工具函数
1.$.browser对象属性 属性列表 说明 webkit webkit相关浏览器则返回true,否则返回false,如google,傲游. mozilla mozilla相关浏览器则返回tru ...
- 分享一个实用任意路数PWM函数
一.什么是PWM? 1.科普一下什么是PWM,嘿嘿,莫闲啰嗦,好好看看,可能大多数人听过,但可能没详细了解过,至此不妨花费几分钟,详细了解哈,PWM中文译名为:脉冲宽度调制,即控制电路在输出频率不变的 ...
- 两个很实用很方便的函数核心及用法{(lower_bound)+(max_element))~~
(1) 关于 lower_bound(a,a+n,x)-a的用法: 求x在数组a中的 ...
- mysql中比较实用的几个函数
1.曾有这样的需求: 可以使用如下函数: 语法:FIND_IN_SET(str,strlist). 定义: 1. 假如字符串str在由N子链组成的字符串列表strlist中,则返回值的范围在1到N之间 ...
- Pyhton实用的format()格式化函数
Python2.6 开始,新增了一种格式化字符串的函数 str.format(),它增强了字符串格式化的功能. 基本语法是通过 {} 和 : 来代替以前的 % . format 函数可以接受不限个参数 ...
- R语言-实用数据对象处理函数
length(object) 显示对象中元素/成分的数量 dim(object) 显示某个对象的维度 str(object) 显示某个对象的结构 class(object) 显示某个对象的类或类型 m ...
随机推荐
- INSTALL_FAILED_MISSING_SHARED_LIBRARY
target选项中要选择Google APIs.如图.
- UIKeyboardTypeNumberPad 数字键盘添加完成按钮
一:添加通知 //数字键盘添加完成 [[NSNotificationCenterdefaultCenter] addObserver:selfselector:@selector(keyboardWi ...
- select的placeholder和分组效果
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
- html字符转义
常用表: No. 文字表記 10進表記 16進表記 文字 Comment 001 " " " """ quotation mark ...
- eclipse git提交代码
1.安装git 2.安装好后,进行,一个简单配置,填入我们的用户名和邮箱 >>Preferences>Team>Git>Configuration 设置自定义仓库 3.登 ...
- HDU 5402 Travelling Salesman Problem(棋盘染色 构造 多校啊)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5402 Problem Description Teacher Mai is in a maze wit ...
- 创建简单的Telnet实例
step1.先加入库SuperSocket.Common.dll, SuperSocket.SocketBase.dll, SuperSocket.SocketEngine.dll,log4net.d ...
- 500 OOPS: chroot
FTP登录时报错: 1.500 OOPS: chroot 解决方法:关闭SElinux 2.500 OOPS: vsftpd: refusing to run with writable root i ...
- 如何使php页面中不再出现NOTICE和DEPRECATED的错误提示
在php.ini配置文件中修改: error_reporting=E_ALL & ~E_NOTICE & ~E_DEPRECATED 亲测有效,拿去用吧
- Hibernate学习备忘
1.关于Hibernate异常: org.hibernate.service.jndi.JndiException: Error parsing JNDI name 刚接触Hibernate,调试 ...