小编典典

为什么在Java中使用request.getParameter()时字符损坏?

java

我在JSP页面中有这样的链接,其编码为big5 http:// hello / world?name
=婀ㄉ
,当我在浏览器的URL栏中输入该链接时,它将被更改为类似
http:// hello / world?name = %23%24%23
而且,当我们想在jsp页面中获取此参数时,所有字符都已损坏。

并且我们已设置为:request.setCharacterEncoding(“ UTF-8”),因此所有请求都将转换为UTF8。

但是,为什么在这种情况下不起作用?提前致谢!。


阅读 211

收藏
2020-10-12

共1个答案

小编典典

在浏览器的地址栏中输入URL时,浏览器可能会在URL编码之前转换字符编码。但是,这种行为的定义不明确,请参阅我的问题,

在Tomcat上处理URI中的字符编码

我们大多在较新的浏览器上获得UTF-8和Latin-1,但在旧的浏览器中我们获得了各种编码(包括Big5)。因此,最好避免用户直接输入的URL中的非ASCII字符。

如果该URL嵌入在JSP中,则可以通过这样生成URL来将其强制为UTF-8,

String link = "http://hello/world?name=" + URLEncoder.encode(name, "UTF-8");

在Tomcat上,需要像这样在Connector上指定编码,

<Connector port="8080" URIEncoding="UTF-8"/>

您还需要使用request.setCharacterEncoding("UTF-8")主体编码,但是在servlet中进行设置是不安全的,因为仅当未处理参数但其他过滤器或阀门可能触发处理时才起作用。因此,您应该在过滤器中进行过滤。Tomcat在源代码发行版中附带了这样的过滤器。

2020-10-12