尽管使用 htmlspecialchars 对单引号进行编码,但 JavaScript 仍然抱怨这些引号需要在函数调用中转义

如何解决尽管使用 htmlspecialchars 对单引号进行编码,但 JavaScript 仍然抱怨这些引号需要在函数调用中转义

发生了一些奇怪的事情,我被难住了。

我有一个基本上像这样的链接

<a href="javascript:uploadVariantPicture('size:&#039;test2&#039');">Link</a>

如您所见,我正在使用参数“size:'test2'”调用函数uploadVariantPicture。

然而,当我真正点击链接时,JavaScript 会抱怨两个编码的单引号没有被转义。我收到以下错误

语法错误:意外的标识符“test2”。需要“)”来结束参数列表。

如果我解码两个编码的单引号并使用反斜杠将它们转义,则函数调用成功。但问题是我需要对它进行编码。我不能让它未编码并转义引号。这对我的情况不起作用。

非常感谢任何帮助。我超级困惑。

解决方法

HTML 字符实体和转义符在解析源时被 HTML 解析器替换。对于引号,它允许在用于引用源中的属性值的 HTML 属性中包含相同类型的引号。

例如

 <element attribute="&quot;">
 <element attribute='&#039;'>

在源代码中将分别产生 "(双引号)和 '(单引号)的属性值,尽管它们是用于引用 HTML 源代码中的属性值的分隔符。

因此

 <a href="javascript:uploadVariantPicture('size:&#039;test2&#039');">Link</a>

将产生一个 href 属性值

  javascript:uploadVariantPicture('size:'test'');

在 HTML 解析器删除外部双引号之后。

选项可以包括在 &quot; 值内适当地转义双引号 (HTML href)(这取决于 uploadVariantPicture 接受的语法),包括上述单引号之前的反斜杠转义在帖子中,或者根本不使用 javascript: 伪协议,赞成在 JavaScript 中添加事件侦听器。

强烈建议不要使用 javascript: 伪协议 - 基本上它是 HTML3 的保留。

,

考虑使用 JavaScript 正确附加事件处理程序,这样您就不必担心转义问题,并且不必依赖全局对象的污染来使脚本工作:

const uploadVariantPicture = (arg) => console.log(arg);

document.querySelector('a').addEventListener('click',() => {
  uploadVariantPicture("size:'test2'");
});
<a>Link</a>

我想不出任何内联处理程序比 addEventListener 更可取的情况,除非您故意尝试利用 XSS 漏洞。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?