php安全处理 过滤函数,PHP中我几个常用安全过滤函数

本文详细介绍了PHP中的几个关键安全函数:htmlentities()用于将字符转为HTML实体,包括ASCII和ISO8859-1实体;htmlspecialchars()则只转换预定义的ASCII实体;html_entity_decode()和htmlspecialchars_decode()则是它们的逆操作,将HTML实体转回字符。这些函数在防止XSS攻击中起到重要作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

php中我讲到的安全函数有htmlentities() 和htmlspecialchars() html_entity_decode()和htmlspecialchars_decode() addslashes()和addcslashes()这几个函数了,下面本文章重点介绍一下这6个函数.

一、htmlentities() 和htmlspecialchars()

1、htmlentities()

1.1  功能:把字符转换为 HTML 实体,字符包括ASCII实体和ISO 8859-1实体(HTML实体对照表:http://www.w3school.com.cn/tags/html_ref_entities.html)

1.2  语法:htmlentities(string,quotestyle,character-set)

1.3  参数:string是必选参数,是需要转换的字符串,其余可选,quotestyle规定如何编码单引号和双引号:ENT_COMPAT – 默认,仅编码双引号;ENT_QUOTES – 编码双引号和单引号;ENT_NOQUOTES – 不编码任何引号,character-set是规定转换用的字符集,常用的有UTF-8/GB-2312/ISO-8859-1(默认).

1.4  提示:无法被识别的字符集将被忽略,并由 ISO-8859-1 代替.

$str="John & 'Adams'";

echohtmlentities($str);

//在浏览器中输出:John & 'Adams'

//查看源代码:John & 'Adams'

2、htmlspecialchars()

2.1 把一些预定义的字符转换为 HTML 实体,预定义字符都是ASCII 实体,即此函数不能转换ISO 8859-1实体,这是和htmlrntities()的区别.

预定义的字符是:

& (和号) 成为 &

” (双引号) 成为 "

‘ (单引号) 成为 '

> (大于) 成为 >

2.2  htmlspecialchars(string,quotestyle,character-set)

2.3  参数htmlentities()

2.4  提示:无法被识别的字符集将被忽略,并由 ISO-8859-1 代替.

$str="John & 'Adams'";

echohtmlentities($str);

//在浏览器中输出:John & 'Adams'phpfensi.com

//查看源代码:John & 'Adams'

二、html_entity_decode()和htmlspecialchars_decode()

html_entity_decode(string,quotestyle,character-set) 函数把 HTML 实体转换为字符,是htmlentities()的.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值