- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在使用此处描述的方法 (How to use XMLReader in PHP?) 处理外部 xml 文档,但我遇到了这个错误:
...parser error : Entity 'Atilde' not defined in...
和类似的,比如
cent, acirc, not
错误发生在 $z->expand() 函数上。如果我将其注释掉,它会出现在 $z->next() 函数上。
我知道问题字段并在扩展之前尝试使用 base64_encode 对其进行编辑,但它是只读的。
编辑:问题字符串是:
...ââ¬Â...
结束编辑
感谢您提供的任何帮助。
最佳答案
XML does only know the entities lt, gt, amp, apos, and quot.所以任何其他 entity reference会引发错误。 (注意 character references 和实体引用不一样。)
您可以使用 strtr
转换 XML 中未知的任何 HTML 实体引用:
$trans = array_map('utf8_encode', array_flip(array_diff(get_html_translation_table(HTML_ENTITIES), get_html_translation_table(HTML_SPECIALCHARS))));
$output = strtr($input, $trans);
get_html_translation_table
返回一个数组,用于将字符映射到实体引用。 get_html_translation_table(HTML_ENTITIES)
返回所有实体的映射,而 get_html_translation_table(HTML_SPECIALCHARS)
仅返回上述实体。 array_diff
会有所不同,因此所有没有上述实体的实体。 array_flip
反转键/值关联并应用 array_map
与 utf8_encode
会将值从 ISO 8859-1 转换为 UTF-8。
关于htmlentities 的 PHP XMLReader 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7272938/
我找到了一些提到这个问题的帖子,但没有一个能完全解决它。 我需要一个函数来输出内容,以 htmlentities() 的方式转换所有特殊字符,但保留所有 html 标签。 我尝试了很多不同的方法,但正
现在我正在尝试通过 htmlentities() 函数运行数组中每一行(“记录”/对象)的一个属性/“列”。因为只有该属性/列包含将在 DOM html 中输出的字符串。 但是,我正在获取所需的行并将
我正在尝试将单引号 (') 简单转换为 html 实体 (') 但无法弄清楚为什么这不起作用. $test = "Bob's House"; echo htmlentities($test,ENT_Q
我正在尝试将单引号 (') 简单转换为 html 实体 (') 但无法弄清楚为什么这不起作用. $test = "Bob's House"; echo htmlentities($test,ENT_Q
我有一个 div id="ultimativegodemperorofalldivs"它包含一些文本,例如“such a cool & sexy div” 当我用 JS 提取 InnerHTML 时,
我正在从数据库中提取数据(原始): long's streetWe’d " tree 根据我的理解,为了将其输出到 html 页面,我应该需要将其包装在 htmlEntities 中。 但是当我包装
我正在使用 htmlentities() 将 Ç 和 ® 等字符转换为其字符代码。我正在从 MYSQL 数据库中获取文本。 while($row = mysql_fetch_array($array,
我正在尝试做一些 htmlentities。但是,由于超链接被转换为 html 代码,现在超链接被破坏了,出于一些愚蠢的原因,大学为我们提供了相同的服务器密码。 去年我几乎失败了,因为有人进入我的服务
我正在 PDO 类的帮助下使用 PHP 和 MySQL 创建一个论坛。我刚刚开始编写论坛代码并遇到了一个问题。 我做的是那个 $post_body = htmlentities($_POST['pos
我们有一个网络应用程序,我们允许用户在文本区域中输入他们自己的 html。我们将该数据保存到我们的数据库中。 当我们将html数据加载到文本区域时,当然是在将html数据扔到文本区域之前使用htmle
我只想将未编码的字符转换为 html 实体,而不影响已经存在的实体。我有一个字符串,其中包含以前编码的实体,例如: gaIUSHIUGhj>‐ hjb×jkn.jhuh>hh
当然,这个问题之前已经被问过,并且已经在寻找解决方案,但到目前为止都没有奏效。我想通过使用 htmlentities 或 htmlspecialchars 将 TM 符号和符号更改为它们的 html
我在问自己使用 php 函数 htmlentities() 来对抗 XSS 攻击的安全性,也许还有相关函数,如 htmlspecialchars。 非常感谢:) 最佳答案 您将需要明确指定正确的编码(
我正在尝试显示字符 html 实体 echo htmlentities(htmlentities("&")); //outputs & echo htmlentities(htmlentiti
我们用什么条件来决定何时设置双重编码是真还是假?我们可以使用什么 php 设置变量来决定它? 对于俄语字符,它应该使用双重编码 true 然后它会显示字符。但是如果 double encoded 为
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: PHP htmlentities() on input before DB insert, instead
我正在使用 htmlentites()用安全的 html 替换字符,即 PHP,因为我希望能够显示 PHP 示例。我遇到的问题是所有标签都被替换了(例如:、 等)。我知道我可以编写自定义 htment
我有一个 .NET MVC 页面,其中包含每个项目的列表 rel 中的编码描述.我希望能够搜索带有 rel 的所有项目包含我的搜索查询。 其中一个字段的值为 htmlentities rel='D&
对于像áéí这样的特殊字符,我可以调用htmlentities(): $mycaption = htmlentities($mycaption, ENT_QUOTES); 获取对应的html实体: &
以下代码输出一个空字符串。原因是 $text 中的“ó”,但为什么呢?那么utf-8编码的是什么字符呢? 使用iso-8859-1的时候问题解决了,但是我需要使用utf-8,我做错了什么?
我是一名优秀的程序员,十分优秀!