- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我的 Java webapp 有问题。
这是 index.jsp 中的代码:
<%@page contentType="text/html" pageEncoding="UTF-8" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<% request.setCharacterEncoding("UTF-8");
response.setCharacterEncoding("UTF-8");
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>JSP Page</title>
</head>
<body>
<h1>Hello World!</h1>
<form action="index.jsp" method="get">
<input type="text" name="q"/>
</form>
Res: <%= request.getParameter("q") %>
</body>
</html>
当我对请求进行wireshark 时,我的浏览器会发送此 header :
GET /kjd/index.jsp?q=%C3%A9 HTTP/1.1\r\n
...
Accept-Charset: UTF-8,*\r\n
Tomcat 服务器返回给我这个:
Content-Type: text/html;charset=UTF-8\r\n
但如果我在表单中发送“é”(UTF-8 中的 %C3%A9),则会显示“é”。
我的理解是浏览器发送一个用 UTF-8 编码的“é”(%C3%A9)。
但服务器将此解释为 ISO-8859-1。所以 %C3 被解码为 Ã 和 %A9 被解码为 ©,然后发回以 UTF-8 编码的响应。
在代码中,请求应该使用 UTF-8 解码:
request.setCharacterEncoding("UTF-8");
但是,如果我发送这个网址:
http://localhost:8080/kjd/index.jsp?q=%E9
“%E9”使用 ISO-8859-1 解码并显示“é”。
为什么这不起作用?为什么使用 ISO-8859-1 对请求进行解码?
我已经在 Tomcat 6 和 7 以及 Windows 和 Ubuntu 上尝试过。
最佳答案
request.setCharacterEncoding("UTF-8");
只设置请求 body 的编码(用于 POST 请求),而不设置请求 URI 的编码(用于 GET 请求)。
您需要设置URIEncoding
归属于 UTF-8
在 <Connector>
Tomcat 的 /conf/server.xml
的元素让 Tomcat 将请求 URI(和查询字符串)解析为 UTF-8。这确实默认为 ISO-8859-1。另见Tomcat HTTP Connector Documentation .
<Connector ... URIEncoding="UTF-8">
或确保使用与正文相同的编码来解析 URI1:
<Connector ... useBodyEncodingForURI="true">
1 来自 Tomcat's documentation (强调我的):
This setting is present for compatibility with Tomcat 4.1.x, where the encoding specified in the contentType, or explicitly set using Request.setCharacterEncoding method was also used for the parameters from the URL. The default value is false.
请删除您的 JSP 中的那些 scriptlet。 request.setCharacterEncoding("UTF-8");
在错误的时刻被调用。每当您正确使用 Servlet 来处理请求时,都为时已晚。您宁愿使用 filter为了这。 response.setCharacterEncoding("UTF-8");
部分已由 pageEncoding="UTF-8"
隐式完成在 JSP 的顶部。
我也是strongly recommend替换老式的<%= request.getParameter("q") %>
scriptlet 来自 EL ${param.q}
, 或使用 JSTL XML 转义 ${fn:escapeXml(param.q)}
防止XSS attacks .
关于java - 如何在Tomcat中设置请求编码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6876697/
我对自定义 CSS 或在将图像作为 Logo 上传到页面时使用编码 block 有疑问。我正在为我的网站使用 squarespace,我需要帮助编码我的 Logo 以使其适合每个页面。一个选项是使用自
如 encoding/json 包文档中所述, Marshal traverses the value v recursively. If an encountered value implement
我必须做一些相当于Java中的iconv -f utf8 -t sjisMS $INPUT_FILE的事情。该命令在 Unix 中 我在java中没有找到任何带有sjisMS的编码。 Java中有Sh
从 PHP 5.3 迁移到 PHP 5.6 后,我遇到了编码问题。我的 MySQL 数据库是 latin1,我的 PHP 文件是 windows-1251。现在一切都显示为“ñëåäíèòå àäðå
我有一个 RScript文件(我们称之为 main.r ),它引用了另一个文件,使用以下代码: source("functions.R") 但是,当我运行 RScript 文件时,它提示以下错误:
我无法设法从 WSDL 创建 RPC/编码风格的代码 - 有谁知道哪个框架可以做到这一点? 带有 adb 和 xmlbeans 映射的 Axis2 无法正常工作(无法处理响应中的肥皂编码)直接使用 X
安装了最新版本的Node.Js()和npm包**(1.2.10)**当我运行 Express 命令来生成项目时,它向我抛出以下错误 buffer.js:240 switch (encoding &
JavaScript中有JSON编码/解码base64编码/解码函数吗? 最佳答案 是的,btoa() 和 atob() 在某些浏览器中可以工作: var enc = btoa("this is so
>>> unicode('восстановление информации', 'utf-16') Traceback (most recent call last): File "", line
我当然熟悉 java.net.URLEncoder 和 java.net.URLDecoder 类。但是,我只需要 HTML 样式的编码。 (我不想将 ' ' 替换为 '+' 等)。我不知道任何只做
有一个非常简单的 SSIS 包: OLE DB Source 通过 View 获取数据(数据库表 nvarchar 或 nchar 中的所有字符串列)。 派生列,用于格式化现有日期并将其添加到数据集(
我正在使用一个在 Node 中进行base64编码的软件,如下所示: const enc = new Buffer('test', 'base64') console.log(enc) 显示: 我正
我试图将带有日语字符的数据插入到 oracle 数据库中。事情是保存在数据库中的是一堆倒置的问号。我该如何解决这个问题 最佳答案 见 http://www.errcode.net/blogs/?p=6
当我在 java 中解压 zip 文件时,我发现文件名中出现了带有重音字符的奇怪行为。 西索: Add File user : L'equipe Technique -- Folder : spec
在网上冲浪我找到了 ExtJS 的 Ext.Gantt 插件,该扩展有一个特殊的编码。任何人都知道如何编码那样或其他复杂的形式。 Encoded Gantt Chart 最佳答案 它似乎被 Dean
我正在用C语言做一个编码任务,我进展顺利,直到读取符号并根据表格分配相应的代码的部分。我必须连接几个代码,直到它们的长度达到 32 位,为此我必须将它们写入一个文件中。这种写入文件的方法给我带来了很多
我有一个外部链接的 javascript 文件。在那个 javascript 里面,我有这个功能: function getMonthNumber(monthName){ monthName = mo
使用mechanize,我检索到一个网页的源页面,其中包含一些非ASCII字符,比如汉字。 代码如下: #using python2.6 from mechanize import Browser b
我有一个包含字母 ø 的文件。当我用这段代码 File.ReadLines(filePath) 读取它时,我得到了一个问号而不是它。 当我像这样添加编码时 File.ReadLines(filePat
如何翻译下面的字符串 H.P. Dembinski, B. K\'{e}gl, I.C. Mari\c{s}, M. Roth, D. Veberi\v{c} 进入 H. P. Dembinski,
我是一名优秀的程序员,十分优秀!