大家好,又见面了,我是你们的朋友全栈君。
一、request获取表单提交中文数据乱码问题的解决
post提交方式处理中文方法
代码语言:javascript复制 通过post方式提交form表单时,首先会把数据放到request缓冲区里面,request缓冲区默认编码是 iso8859-1,这个编码不支持中文,所以解决这个问题的方法就是设置request缓冲区的编码,即
代码语言:javascript复制 request.setCharacterEncoding("utf-8");
2、get提交方式处理中文方法 get提交方式有四种处理方案
- 修改tomcat的配置文件 * 找到tomcat({tomcat}confserver.xml)的server.xml,找到修改端口的地方,添加一个属性 URIEncoding=”utf-8”
<Connector port="80" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443“ URIEncoding="utf-8"/>
- 先对数据进行编码,再进行解码
String username="中国";
username = URLEncoder.encode(username, "utf-8");
System.out.println("URLEncoder=" username);
username = URLDecoder.decode(username, "utf-8");
System.out.println("URLDecoder=" username);
- 使用string的构造完成编码(这个比较常用)
username = new String(username.getBytes("utf-8"),"utf-8");
- 直接在html的head中指定编码集(简单暴力)
<meta charset="utf-8">
二、response向页面输出中文乱码问题的解决
代码语言:javascript复制 1)、 **使用字节流向页面输出中文**
* 使用字节流向页面输出中文不一定会出现乱码问题,如果出现中文乱码问题,需要设置浏览器编码和设置字节数组的编码, 让这两个编码一样,不会有乱码问题
代码语言:javascript复制//设置浏览器的编码
response.setHeader("Content-Type", "text/html;charset=utf-8");
//设置字节数组的编码
response.getOutputStream().write("字节流中文输出".getBytes("utf-8"));
2、) 使用字符流向页面输出中文 * 使用字符流向页面输出中文一定会产生乱码
代码语言:javascript复制 使用字符流输出中文,输出机制:首先把输入的内容放到response缓冲区里面,通过缓冲区向页面输出, 在response缓冲区里面有默认的编码 iso8859-1,该编码 不支持中文,设置response缓冲区,支持中文的编码,所以保持缓冲区和浏览器的编码一致就ok了。
代码语言:javascript复制//设置response缓冲区的编码
response.setCharacterEncoding("utf-8");
//设置浏览器的编码
response.setHeader("Content-Type", "text/html;charset=utf-8");
//使用字符流输出中文
response.getWriter().write("字符流中文");
上面可以简写一行代码:
代码语言:javascript复制response.setContentType("text/html;charset=utf-8");
*注意:字节流和字符流向页面输出数据,不能同时使用(互斥的)。 使用字符流不能直接向页面输出数字(因为默认走ASCII,比如response.getOutputStream().write(97); 的输出结果是字符 a)
三、下载文件时,中文文件名乱码问题的解决
代码语言:javascript复制由于不同的浏览器采用不同的编码方式,所以需要根据不同的浏览器进行不同的处理。IE采用url编码,火狐浏览器采用base64编码,所以我们首先要知道用户使用的是什么内核的浏览器,通过
代码语言:javascript复制request.getHeader("User-Agent");
可以从请求头里面获取到浏览器的类型,然后做以下操作
代码语言:javascript复制//判断不同的浏览器,使用头User-Agent
String agent = request.getHeader("User-Agent");
//如果是火狐浏览器
if(agent.contains("Firefox")) {
//火狐采用base64编码
filename = "=?UTF-8?B?"
new BASE64Encoder().encode(filename.getBytes("utf-8")) "?=";
} else {
//ie浏览器使用url编码
filename = URLEncoder.encode(filename, "utf-8");
}
注意:文件下载需要设置以下头信息,无论文件是什么格式,都以下载的方式打开,而不会在浏览器里面直接显示出来
代码语言:javascript复制response.setHeader("Content-Disposition", "attachment;filename=" filename);
总结
个人认为,框架很好用,基础很重要。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/156790.html原文链接:https://javaforall.cn