zoukankan      html  css  js  c++  java
  • 浅析PHP中处理HTML特殊字符转换

    我们在用PHP处理页面显示内容时,经常会遇到一些特殊字符转换问题,如果处理不当就会导致页面显示混乱,不能得到目标效果。所以本文我们将和大家一起归纳总结PHP中处理HTML特殊字符转换的常用方法。

    HTML实体字符

    我们知道HTML中有许多特殊的预留字符不能直接输出到浏览器,必须把它们替换为相应的实体字符才可以正常显示,比如空格、<、>等。

    HTML常用字符实体一览:


    图片来源:http://www.w3school.com.cn/html/html_entities.asp

    我们在写HTML代码时,可以直接在代码中将想显示的特殊字符写成实体字符:

     1 <html>
     2 <head>
     3  <meta charset="utf-8">
     4 </head>
     5 <body>
     6 <h3>HTML中超链接a标签是这个样子的:</h3>
     7 <p>&lt;a href=&#039;http://www.chanzhi.org&#039;&gt;蝉知企业门户系统&lt;/a&gt;</p>
     8 
     9 </body>
    10 </html>

    显示效果如下:


    htmlentities()

    在写PHP代码时,不能在字符串中直接写实体字符,PHP提供了一个将HTML特殊字符转换成实体字符的函数 htmlentities()

    注:htmlentities()并不能转换所有的特殊字符,是转换除了空格之外的特殊字符,且单引号和双引号需要单独控制(通过第二个参数)。

    第二个参数有三个值:

    ENT_COMPAT(默认值):只转换双引号。

    ENT_QUOTES:两种引号都转换。

    ENT_NOQUOTES:两种引号都不转换。

    (没有只转换单引号的参数选项)

    1 <?php
    2 $str = "<a href='http://www.chanzhi.org'>蝉知企业门户系统©</a>";
    3 
    4 //使用htmlentities()函数将特殊字符转换为实体字符
    5 $str2 = htmlentities($str);
    6 
    7 echo $str2;
    8 ?>

    运行后前台显示特殊字符正常,右击查看页面源代码,可以看到PHP转换后的实体字符内容。


    前台浏览器显示


    查看页面源代码

    htmlspecialchars()

    htmlspecialchars()函数只对HTML语法字符进行转换,目的是避免这些特殊的字符扰乱HTML代码。
    这里说的 HTML语法字符 只有5个:

    显示结果描述实体名称
    < 小于号 &lt;
    > 大于号 &gt;
    & 和号 &amp;
    " 双引号 &quot;
    ' 单引号  &apos;


    htmlspecialchars()将其转换成与其对应的实体字符。

    我们还是以上面代码为例,对比htmlentities和htmlspecialchars查看下效果:

    1 <?php
    2 $str = "<a href='http://www.chanzhi.org'>蝉知企业门户系统©</a>";
    3 
    4 //使用htmlspecialchars()函数将特殊字符转换为实体字符
    5 $str2 = htmlspecialchars($str);
    6 
    7 echo $str2;
    8 ?>

    运行效果如下:

    前台浏览器显示

    查看页面源代码

    可以看到,htmlspecialchars只对上面5个特殊语法字符其作用,其他的特殊字符不进行转换。

    小结:

    本文我们一起学习了解了PHP处理HTML中特殊字符的方法。对比htmlentities和htmlspecialchars两个PHP函数的功能作用。如果大家对于字符处理还有其他疑问,欢迎和大家一起分享交流,我们共同学习,共同交流,共同进步。

  • 相关阅读:
    vue-指令
    VueMusic-14搜索实现
    VueMusic-13歌手列表
    VueMusic-12歌词滚动
    VueMusic-11播放-歌词适配
    VueMusic-10.播放-歌词加载
    VueMusic-9.播放-播放功能
    VueMusic-8更多-下拉刷新
    VueMusic-7更多-数据适配
    VueMusic-6首页-热门榜单
  • 原文地址:https://www.cnblogs.com/chanzhi/p/7654382.html
Copyright © 2011-2022 走看看