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 ...
随机推荐
- glassfish--服务搭建
集群配置: 1. DAS节点执行: 1)./asadmin start-domain domain1 2)./asadmin change-admin-password 3)./asadmin ena ...
- php之快速入门学习-3(print和echo)
PHP echo 和 print 语句 echo 和 print 区别: echo - 可以输出一个或多个字符串 print - 只允许输出一个字符串,返回值总为 1 提示:echo 输出的速度比 p ...
- web中的安全编码
个人记录 一.Web安全验证 输入验证 防范跨站脚本XSS攻击 防止SQL注入 图片验证码 二.输入验证 经典的安全法则:永远不要相信用户提交的数据 验证内容: 用户名,密码等格式 验证长度防止数据库 ...
- vb sendmessage 详解2
首先我们了解一下Windows的消息机制.Windows是一个消息驱动式系统,Windows消息提供应用程序与应用程序之间,应用程序与Windows系统之间进行通信的手段.举个例子,打开记事本程序,该 ...
- Java 基础【13】 I/O流概念分析整理
转载地址:http://blog.csdn.net/yuebinghaoyuan/article/details/7388059 java.io 中的流,可以从不同的角度进行分类. 按照数据流的方向不 ...
- inode备忘
文件名 -> inode -> device block 转自:http://www.cnblogs.com/itech/archive/2012/05/15/2502284.html 一 ...
- win7硬盘安装方法
Windows 7 完全硬盘安装方法 干干净净的C盘 事先准备:装好系统的电脑一台,win 7安装iso. 注: (1).Windows 7要求安装在NTFS分区,但是其他分区可以是FAT32格式! ...
- Linux 调优方案, 修改最大连接数-ulimit
Linux对于每个用户,系统限制其最大进程数.为提高性能,可以根据设备资源情况,设置各linux 用户的最大进程数 可以用ulimit -a 来显示当前的各种用户进程限制.下面我把某linux用户的最 ...
- 老男孩Linux.shell.RHCE运维初中高级50G附解压密码
学习Linux,好的教程.使学习事半功倍! 老男孩Linux.shell.RHCE运维初中高级 下载地址: http://pan.baidu.com/s/1hsQOb2W 密码: h4hs 解压密码: ...
- JavaScript-jQuery插件开发全解析
摘自:http://www.iteye.com/topic/545971 jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法 ...