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 ...
随机推荐
- 在MyEclipse中配置Weblogic10服务器
MyEclipse中配置Weblogic10服务器 在MyEclipse中配置Weblogic10服务器也是很简单,现在将过程分享给有需要的人. 1.在下方的Server选项卡中,鼠标右键选择“Con ...
- vb sendmessage 详解2
首先我们了解一下Windows的消息机制.Windows是一个消息驱动式系统,Windows消息提供应用程序与应用程序之间,应用程序与Windows系统之间进行通信的手段.举个例子,打开记事本程序,该 ...
- MVC下的DAO接口类和SERVICE接口类区别?
简单理解: DAO数据库访问对象 实现连接数据库 修改.添加等细节 service服务层 面向功能 把一个整个服务 细化 调用DAO其实service其中都是一些方法 去调用DAO 甚至方法名都和DA ...
- Java的代理模式(通过公共接口实现)
代理模式的一种常见的实现方案是,定义一个接口或抽象类,并派生出目标子类,和代理子类.我们要操作的是目标子类里的方法,而很多时候,我们需要为目录子类中的方法增加额外的处理,如果增加日志功能.条件判断等, ...
- MHDD修复硬盘坏道
2种修复的方法,本人已经尝试过,非常管用! 1.先按SHIFT+F3扫描硬盘连接并选择,按F4键,先用一般模式扫一遍,再用高级模式扫一变,具体方法是选择LBA模式,remap项OFF,Loop the ...
- ubuntu中设置xampp开机启动
sudo ln -s /opt/lampp/lampp /etc/init.d/lampp sudo update-rc.d -f lampp defaults
- 使用autoconfig
1. 增加maven 依赖 <properties> <maven.compiler.target>1.8</maven.compiler.target> < ...
- doGet和doPost区别
1,form运行方式 当form框里面的method为get时,执行doGet方法当form框里面的method为post时,执行doPost方法 2,生成方式 get方式有四种:1)直接在URL地址 ...
- HDUOJ----1170Milk
Milk Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- DataSnap对象传递
比较简单的方法: 1.引用DBXJSON, DBXJSONReflect 假设有一个类: type TKid = class FirstName: String; LastName: String; ...