加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘孜站长网 (https://www.0836zz.com.cn/)- 运维、物联设备、数据计算、智能推荐、云管理!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP中我几个常用安全过滤函数

发布时间:2022-07-29 11:03:48 所属栏目:PHP教程 来源:互联网
导读:php中我讲到的安全函数有htmlentities() 和htmlspecialchars() html_entity_decode()和htmlspecialchars_decode() addslashes()和addcslashes()这几个函数了,下面本文章重点介绍一下这6个函数. 一、htmlentities() 和htmlspecialchars() 1、htmlentities() 1
  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'";
  echo htmlentities($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'";
  echo htmlentities($str);
  //在浏览器中输出:John & 'Adams' phpfensi.com
  //查看源代码:John & 'Adams'
  二、html_entity_decode()和htmlspecialchars_decode()
 
  html_entity_decode(string,quotestyle,character-set) 函数把 HTML 实体转换为字符,是htmlentities()的

(编辑:甘孜站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读