在网页上显示内容之前,我需要对一些文本进行转义,而这实际上是正确完成的。但是,当我在 html 中显示字符串时,仍会显示转义字符。下面就是这样一个例子:
hello there my ni&%ame is + - && !
相应的转义字符串如下:
hello there my ni&%ame is + - && !
我在某处读到,taglib 中的核心只会转义基本的,例如 >、<、"、\t 和空格。但是,这些转义序列都没有从 html 代码中删除。你们有谁知道吗请问如何解决这个问题?谢谢
以下是用于将特定字符转换为其转义字符的部分代码:
while (character != CharacterIterator.DONE ){
if (character == '<') {
result.append("<");
}
else if (character == '>') {
result.append(">");
}
else if (character == '&') {
result.append("&");
} .....
return result;
}
转义部分已完成并完美运行..当我尝试将带有转义字符的字符串显示到 html 页面时出现问题
最佳答案
if (character == '<') {
result.append("<");
}
else if (character == '>') {
result.append(">");
// ...
删除它。你不需要它。江苏科技研究院<c:out>
已经做了这个工作。
<c:out value="${someBean.someProperty}" />
您的 HTML 字符串会被转义两次。每个&
变成 &
再次等等。
如果你真的需要自己动手转义(为什么?)那么就不要使用 <c:out>
完全:
${someBean.someProperty}
或通过 escapeXml="false"
关闭其转义:
<c:out value="${someBean.someProperty}" escapeXml="false" />
关于java - 为什么在 HTML 中显示转义字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8827896/