正如Ryan在Sotirios Delimanolis的回答(非常好)中指出的那样:
- 该Javascript对象符号规范规定
Any character may be escaped
。因此很明显,这意味着即使单引号字符也可以。 - 但是,正如Ryan所指出的(再次在相同的注释中),这由jQuery的Ajax实现引起错误。
因此,似乎这只是一个实现选择,现在使我们面临的标准并不是真正一致地实现的……
无论如何,这是一种解决方法,您可以使用它来使代码正常工作
<%@ page trimDirectiveWhitespaces="true" contentType="json/application"%><%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%><%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %><%-- [1] Removing the escape of the single quote character: jQuery's Ajax cannot handle it stackoverflow.com/questions/25491391/springescapebody-results-in-invalid-json stackoverflow.com/questions/2275359/jquery-single-quote-in-json-response--%><c:set var="someJsonData" > <spring:escapeBody javascriptEscape="true"> if you don't have "user" an account </spring:escapeBody></c:set> { "status": "success", "body" : "${fn:replace(someJsonData, "\'","'")}" , <%-- [1] --%>}
这是
JSTL fn文档
老实说,这可能不是最干净/最好的解决方案。但这会起作用,直到您发现更好为止。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)