返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >在 PHP 中编码 HTML
  • 348
分享到

在 PHP 中编码 HTML

2024-02-27 20:02:31 348人浏览 安东尼
摘要

html 编码是在处理用户提供的数据时试图在 PHP WEB 应用程序中防止跨站脚本 XSS。本教程将教你如何使用 htmlentities()、htmlspecialchars() 和自定义方法对数据

html 编码是在处理用户提供的数据时试图在 PHP WEB 应用程序中防止跨站脚本 XSS。本教程将教你如何使用 htmlentities()htmlspecialchars() 和自定义方法对数据进行编码。


使用 htmlspecialchars() 编码

php htmlspecialchars() 是一个内置函数,可以将特殊字符转换为 HTML 实体。语法如下:


htmlspecialchars( $string, $flags, $encoding, $double_encode )

参数说明:

  • $string: 输入字符串
  • $flags:指示函数应如何处理字符串中的引号的标志
  • $encoding:指定函数使用的编码。该参数是可选的
  • $double_encode:一个布尔属性,指示 PHP 是否将对现有实体进行编码。如果将其设置为 false,PHP 将不会对现有实体进行编码

像所有函数一样,htmlspecialchars() 返回一个值。它的值是转换后的字符串。但是,如果函数认为该字符串无效,它将返回一个空字符串。

下一个示例展示了如何使用 htmlspecialchars() 转换字符串。你会观察到该函数未与任何标志一起使用。


<?php
    $stringToEncode = "A <b>bold text</b> a'nd á <script>alert();</script> tag";

    $encodedString = htmlspecialchars($stringToEncode);

    echo $encodedString;
?>

输出:


A <b>bold text</b> a'nd á <script>alert();</script> tag

当你查看网页的源代码时,你会发现撇号和 á 字符未编码:


A &lt;b&gt;bold text&lt;/b&gt; a'nd á &lt;script&gt;alert();&lt;/script&gt; tag

现在,如果你向 htmlspecialchars() 提供标志和编码格式,撇号会被编码,但 á 不会。


<?php
    $stringToEncode = "A <b>bold text</b> a'nd á <script>alert();</script> tag";

    $encodedString = htmlspecialchars($stringToEncode, ENT_QUOTES, 'UTF-8');
    
    echo $encodedString;
?>

输出:


A <b>bold text</b> a'nd á <script>alert();</script> tag

页面的查看源代码显示浏览器将撇号编码为&#039;


A &lt;b&gt;bold text&lt;/b&gt; a&#039;nd á &lt;script&gt;alert();&lt;/script&gt; tag

htmlentities() 编码

htmlentites() 也是一个内置的 PHP 函数。使用 htmlentities(),所有适用的字符都将转换为 HTML 实体。它的语法如下:


htmlentities( $string, $flags, $encoding, $double_encode )

下面是对参数的解释:

  • $string: 输入字符串
  • $flags:指示函数应如何处理字符串中的引号的标志
  • $encoding:指定函数使用的编码。该参数是可选的
  • $double_encode:一个布尔属性,指示 PHP 是否将对现有实体进行编码。如果将其设置为 false,PHP 将不会对现有实体进行编码

此函数的返回值是编码字符串。

以下是使用 htmlentities() 转换字符串的示例。这里 htmlentities() 不与任何标志一起使用。


<?php    
    $stringToEncode = "A <b>bold text</b> ánd a <script>alert();</script> tag's";

    $ecodedString = htmlentities($stringToEncode);

    echo $ecodedString;
?>

输出:


A <b>bold text</b> ánd a <script>alert();</script> tag's

该页面的视图源显示该函数对á字符进行了编码,没有任何标志,但撇号没有编码。


A &lt;b&gt;bold text&lt;/b&gt; &aacute;nd a &lt;script&gt;alert();&lt;/script&gt; tag's

对代码的更改将允许函数对撇号进行编码。


<?php
    $stringToEncode = "A <b>bold text</b> ánd a <script>alert();</script> tag's";

    $ecodedString = htmlentities($stringToEncode, ENT_QUOTES, 'UTF-8');

    echo $ecodedString;
?>

输出:


A <b>bold text</b> ánd a <script>alert();</script> tag's

查看页面来源:


A &lt;b&gt;bold text&lt;/b&gt; &aacute;nd a &lt;script&gt;alert();&lt;/script&gt; tag&#039;s

使用 htmlentities()HTML5 编码进行编码

当字符串中有非英文字符时,可以使用 HTML 5 标志和 UTF-8 编码。

HTML5 标志指示函数将字符串视为 HTML5,而 UTF-8 标志允许函数理解任何标准 Unicode 字符。

以下是如何使用带有 HTML5 标志和 UTF-8 编码的 htmlentities() 的示例:


<?php
    $stringToEncode = "àéò ©€ ♣♦ ↠ ↔↛ āžšķūņ ↙ ℜ℞ ∀∂∋ rūķīš ○";

    $ecodedString = htmlentities($stringToEncode, ENT_HTML5, 'UTF-8');
    
    echo $ecodedString;
?>

查看页面来源:


&agrave;&eacute;&ograve; &copy;&euro; &clubs;&diamondsuit;
&twoheadrightarrow; &harr;&nrarr; &aMacr;&zcaron;&scaron;
&kcedil;&umacr;&ncedil; &swarr; &Rfr;&rx; &forall;&part;&ReverseElement;
r&umacr;&kcedil;&imacr;&scaron; &cir;

使用自定义方法编码

如果你想滚动编码方案,自定义方法可以派上用场。此方法将获取你的输入字符串并应用一些字符串操作。最后,你会得到一个编码字符串。

下面的 HTML 有一个文本区域和一个提交按钮。表单 action 指向一个文件,该文件将对传递到表单输入的字符串进行编码。


<main>
    <h1>Enter and HTML code and click the submit button</h1>
    <fORM action='encodedoutput.php' method='post'>
        <div class="form-row">
            <textarea rows='15' cols='50' name='texttoencode' required></textarea>
        </div>
        <div class="form-row">
            <input type='submit'>
        </div>
    </form>
</main>

下一个代码块是执行编码的 PHP 代码。将其保存为 encodedoutput.php


<?php
    if (isset($_POST['texttoencode']) && !empty($_POST)) {
        // Check for empty text
        if ($_POST['texttoencode'] == "") {
            echo "Invalid text";
            die();
        }

        $inputHTML = bin2hex($_POST['texttoencode']); 
        $spiltHTML = chunk_split($inputHTML, 2 ,"%");
        $HTMLStringLength = strlen($spiltHTML);
        $HTMLSubLength = $HTMLStringLength - 1;
        $HTMLSubString = substr($spiltHTML,'0', $HTMLSubLength);

        $encodedOutput="<script>document.write(unescape('%$HTMLSubString'));</script>";

    } else {
        echo "Not allowed";
        die();
    }
?>

<textarea rows='15' cols='60'>
    <?php
        if ($encodedOutput) {
            echo $encodedOutput;
        } else {
            echo "";
            die();
        }
    ?>
</textarea>

<script>alert("Hello world");</alert> 的示例输出:


<script>document.write(unescape('%3c%73%63%72%69%70%74%3e%61%6c%65%72%74%28%22%48%65%6c%6c%6f%20%77%6f%72%6c%64%22%29%3b%3c%2f%61%6c%65%72%74%3e'));</script>

--结束END--

本文标题: 在 PHP 中编码 HTML

本文链接: https://lsjlt.com/news/569145.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 在 PHP 中编码 HTML
    HTML 编码是在处理用户提供的数据时试图在 PHP Web 应用程序中防止跨站脚本 XSS。本教程将教你如何使用 htmlentities()、htmlspecialchars() 和自定义方法对数据...
    99+
    2024-02-27
  • 如何在html中设置编码
    如何在html中设置编码?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。html是什么html的全称为超文本标记语言,它是一种标记语言,包含了一系列标签.通过这些标签可以将网...
    99+
    2023-06-14
  • 在 PHP 中将图像编码为 Base64
    借助 PHP 中的多个内置函数,有很多方法可以将图像编码为 base64 格式。 这些函数包括: pathinfo file_get_contents base64_enc...
    99+
    2024-02-27
  • HTML中文编码的方法
    这篇文章主要讲解了“HTML中文编码的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTML中文编码的方法”吧! 目前在大部分浏览器中,直接输出中文会...
    99+
    2024-04-02
  • Python HTML编码解码
    >>> import HTMLParser >>> h = HTMLParser.HTMLParser() &g...
    99+
    2023-01-31
    Python HTML
  • PHP预定义字符串转HTML编码
    ...
    99+
    2024-04-02
  • 浅析怎么在PHP中设置JavaScript编码
    PHP和JavaScript是两种不同的编程语言,但它们可以结合使用,许多PHP网站都包含JavaScript脚本。在使用这两种编程语言的时候,设置编码十分重要,以保证网站的正确显示。在PHP中设置JavaScript编码PHP可以使用he...
    99+
    2023-05-14
  • php中编码转换
    使用iconv函数转换字符编码,该函数仅能在PHP4.0.5以上版本或PHP5.x版本使用,具体用法如下: $string=iconv(原字符编码, 字符输出编码, $string); 例如:网页使用gbk编码,字符串使用utf-...
    99+
    2023-09-02
    html php javascript
  • PHP 中的 URL 编码
    URL 可能具有路径和查询参数,例如某人的全名、另一个重定向 URL 或密码。它们可以包含 ASCII 集之外的特殊字符,如空格或 $ & : / 等字符。因此,在通过 Internet 传输之前,...
    99+
    2024-02-27
  • PHP中怎么截取HTML代码
    PHP中怎么截取HTML代码,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。需求:将一段文字截取一定的物理长度显示,注意,要截取的不是字符串的字节数,UFT-8 的编码中文字...
    99+
    2023-06-17
  • html UTF8在IE中不能自动选择编码怎么解决
    本篇内容介绍了“html UTF8在IE中不能自动选择编码怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2024-04-02
  • myeclipse中怎么设置html文件编码
    这篇文章给大家介绍myeclipse中怎么设置html文件编码,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。设置方法:1、打开myeclipse软件,点击菜单栏中的“windows”-...
    99+
    2024-04-02
  • 如何声明HTML中的字符编码
    本篇内容介绍了“如何声明HTML中的字符编码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 元标记通常用...
    99+
    2024-04-02
  • 怎么在php中设置文件的编码格式
    这期内容当中小编将会给大家带来有关怎么在php中设置文件的编码格式,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。设置php文件编码格式的方法:首先使用notepad++软件打开php文件;然后点击顶部导航...
    99+
    2023-06-14
  • HTML的编码是什么
    这篇文章主要为大家展示了“HTML的编码是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“HTML的编码是什么”这篇文章吧。 常见编码个格式: UTF-8...
    99+
    2024-04-02
  • 如何在文本编辑器中编辑HTML文件
    HTML是一种标记语言,用于创建网页和其他文档。如果你想学习HTML,在你的计算机上需要有一个文本编辑器,这篇文章将介绍如何在文本编辑器中编辑HTML文件,并提供一些提示和技巧。选择文本编辑器首先,你需要选择一个文本编辑器,它应该是可以在你...
    99+
    2023-05-14
  • PHP——json_encode中文编码问题
    在PHP项目中会经常遇到中文乱码,这是一个比较恼人的问题。不过,当需要将内容输出到网页上的时候,我们遵照以下两个原则一般情况下是不会出现中文乱码的。 第一就是在html头部添加 <meta...
    99+
    2024-02-27
  • 如何在浏览器中编写PHP代码并仅显示代码?
    如何在浏览器中编写PHP代码并仅显示代码? 在今天的技术发达的年代,学习如何在浏览器中编写PHP代码并仅显示代码是一项非常有用的技能。在Web开发领域,PHP是一种流行的服务器端脚本语...
    99+
    2024-03-09
    php代码显示 浏览器编程 代码展示
  • UTF-8编码在PHP中的应用及常见问题
    UTF-8编码在PHP中的应用及常见问题 在网络时代,我们经常会碰到各种不同语言和字符集的数据交互,而UTF-8编码则是一种通用的字符编码方式,能够很好地解决多语言字符的显示和传输问题...
    99+
    2024-04-02
  • 在文档中怎么写HTML代码
    本文小编为大家详细介绍“在文档中怎么写HTML代码”,内容详细,步骤清晰,细节处理妥当,希望这篇“在文档中怎么写HTML代码”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 (1...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作