struts2中文乱码问题
2017-08-19 17:33
405 查看
(一)中文乱码,首先要区分是页面乱码、action乱码,还是数据库乱码。
大致的原理是java使用unicode编码-->window使用gbk(gb2312的扩展集)--mysql默认使用utf-8(unicode的一种编码方法),这样转来转去就乱码了
(1)页面中文乱码
对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件中是不是出现了中文要处理。由于JSP默认的编码格式为“ISO-8859-1”。
jsp代码:<%@ page language="java" import="java.util." pageEncoding="ISO-8859-1">
改成:
jsp代码:<%@ page language="java" import="java.util." pageEncoding="UTF-8">
(推荐)
<%@
page language="java"
contentType="text/html;
charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page language="java" import="java.util.*"contentType="text/html;
charset=UTF-8" %>
HTML代码:在<head>标签中添加:<metacharset="utf-8">
pageEncoding
在JSP标准的语法中,如果pageEncoding属性存在,那么JSP页面的字符编码方式就由pageEncoding决定,否则就由contentType属性中的charset决定,如果charset也不存在,JSP页面的字符编码方式就采用默认的ISO-8859-1。
pageEncoding是jsp文件本身的编码
contentType的charset是指服务器发送给客户端时的内容编码
(2)传递参数乱码
在form表中中文乱码直接设置constant
1、在struts.xml中设置默认字符集:<constant name="struts.i18n.encoding" value="UTF-8" />
或者 在struts.properties中设置:struts.i18n.encoding=UTF-8
constant要与jsp页面的字符编码一致,可以统一设置为UTF-8,这样乱码问题就可以解决
2、如果使用了spring可以在web.xml中添加字符集过滤器filter,因为拦截有顺序,该过滤器必须放在最前面
<filter>
<filter-name>characterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
也可以在action中设置字符编码
HttpServletResponseresponse = null;
response
=ServletActionContext.getResponse();
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
3、url中文参数乱码以上方法不行,直接设置tomcat中conf文件夹下的server.xml文件。
添加 URIEncoding="UTF-8"。如果你正在使用eclipse,记得重启eclipse,把服务器的设置删除,重新设置。
1、Filter接口:
三个方法说明:
*public void init(FilterConfig filterConfig)throws ServletException//过滤器初始化方法,此方法在过滤器初始化时被调用
*public void doilter(ServletRequest request , ServletResponse response,FilterChain chain)throws IOException, ServletException//对请求进行过滤 处理
*public void destroy();//销毁方法,以便释放资源
2、FilterConfig接口
*public Strng getFilterName();//用于获取过滤器的名字
*public ServletContext getServletContent();//获取Servlet上下文
*public String getInitParameter(String name);//获取过滤器的初始化参数值
*public Enumeration getInitParameterNames();//获取过滤器的所有初始化参数
[5]FilterChain接口
public void doFilter(ServletRequest request request, ServletResponse response)throws IOException , ServletException
3、自定义过滤器
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class CharactorFilter implements Filter {
// 字符编码
String encoding = null;
public void destroy() {
encoding = null;
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// 判断字符编码是否为空
if(encoding != null){
// 设置request的编码格式
request.setCharacterEncoding(encoding);
// 设置response字符编码
response.setContentType("text/html; charset="+encoding);
}
// 传递给下一过滤器
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
// 获取初始化参数
encoding = filterConfig.getInitParameter("encoding");
}
}
4、过滤器在web.xml中的配置
<!-- 声明过滤器 -->
<filter>
<!-- 过滤器名称 -->
<filter-name>CharactorFilter</filter-name>
<!-- 过滤器的完整类名 -->
<filter-class>com.lyq.CharactorFilter</filter-class>
<!-- 初始化参数 -->
<init-param>
<!-- 参数名 -->
<param-name>encoding</param-name>
<!-- 参数值 -->
<param-value>UTF-8</param-value>
</init-param>
</filter>
<!-- 过滤器映射 -->
<filter-mapping>
<!-- 过滤器名称 -->
<filter-name>CharactorFilter</filter-name>
<!-- URL映射 -->
<url-pattern>/*</url-pattern>
</filter-mapping>
(4)从数据库取值乱码:比如mysql,确认你的数据库内字符是gbk,并且连接字符串指定了字符编码
<property name="url" value="jdbc:mysql://localhost/database?useUnicode=true&characterEncoding=gbk"></property>
(5)在action中直接使用request.getParameter()时;还是出现乱码。原因分析如下:
1、getParameter()是有带字符参数的。例:
String s =(String)request.getParameter("txt").getBytes("iso-8859-1");
2、String也可以带有字符参数。
String(byte[] bytes, String charsetName)
构造一个新的String,方法是使用指定的字符集解码指定的字节数组。
例:String s = new String("中文","utf-8");
3、综合上述两点,编写一个类来完成此项任务
public classConvertCharacter{
public String Convert(String s){
String result;
byte[] temp ;
try{
temp = s.getBytes("iso-8859-1");
result = new String(temp,"utf-8");
}
return result;
}
}
大致的原理是java使用unicode编码-->window使用gbk(gb2312的扩展集)--mysql默认使用utf-8(unicode的一种编码方法),这样转来转去就乱码了
(1)页面中文乱码
对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件中是不是出现了中文要处理。由于JSP默认的编码格式为“ISO-8859-1”。
jsp代码:<%@ page language="java" import="java.util." pageEncoding="ISO-8859-1">
改成:
jsp代码:<%@ page language="java" import="java.util." pageEncoding="UTF-8">
(推荐)
<%@
page language="java"
contentType="text/html;
charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page language="java" import="java.util.*"contentType="text/html;
charset=UTF-8" %>
HTML代码:在<head>标签中添加:<metacharset="utf-8">
pageEncoding
在JSP标准的语法中,如果pageEncoding属性存在,那么JSP页面的字符编码方式就由pageEncoding决定,否则就由contentType属性中的charset决定,如果charset也不存在,JSP页面的字符编码方式就采用默认的ISO-8859-1。
pageEncoding是jsp文件本身的编码
contentType的charset是指服务器发送给客户端时的内容编码
(2)传递参数乱码
在form表中中文乱码直接设置constant
1、在struts.xml中设置默认字符集:<constant name="struts.i18n.encoding" value="UTF-8" />
或者 在struts.properties中设置:struts.i18n.encoding=UTF-8
constant要与jsp页面的字符编码一致,可以统一设置为UTF-8,这样乱码问题就可以解决
2、如果使用了spring可以在web.xml中添加字符集过滤器filter,因为拦截有顺序,该过滤器必须放在最前面
<filter>
<filter-name>characterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
也可以在action中设置字符编码
HttpServletResponseresponse = null;
response
=ServletActionContext.getResponse();
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
3、url中文参数乱码以上方法不行,直接设置tomcat中conf文件夹下的server.xml文件。
1和2都只能设置post方式提交数据的编码方式,如果url有中文的话就会有乱码,解决办法是在
tomcat的\conf\server文件的
1、Filter接口:
三个方法说明:
*public void init(FilterConfig filterConfig)throws ServletException//过滤器初始化方法,此方法在过滤器初始化时被调用
*public void doilter(ServletRequest request , ServletResponse response,FilterChain chain)throws IOException, ServletException//对请求进行过滤 处理
*public void destroy();//销毁方法,以便释放资源
2、FilterConfig接口
*public Strng getFilterName();//用于获取过滤器的名字
*public ServletContext getServletContent();//获取Servlet上下文
*public String getInitParameter(String name);//获取过滤器的初始化参数值
*public Enumeration getInitParameterNames();//获取过滤器的所有初始化参数
[5]FilterChain接口
public void doFilter(ServletRequest request request, ServletResponse response)throws IOException , ServletException
3、自定义过滤器
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class CharactorFilter implements Filter {
// 字符编码
String encoding = null;
public void destroy() {
encoding = null;
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// 判断字符编码是否为空
if(encoding != null){
// 设置request的编码格式
request.setCharacterEncoding(encoding);
// 设置response字符编码
response.setContentType("text/html; charset="+encoding);
}
// 传递给下一过滤器
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
// 获取初始化参数
encoding = filterConfig.getInitParameter("encoding");
}
}
4、过滤器在web.xml中的配置
<!-- 声明过滤器 -->
<filter>
<!-- 过滤器名称 -->
<filter-name>CharactorFilter</filter-name>
<!-- 过滤器的完整类名 -->
<filter-class>com.lyq.CharactorFilter</filter-class>
<!-- 初始化参数 -->
<init-param>
<!-- 参数名 -->
<param-name>encoding</param-name>
<!-- 参数值 -->
<param-value>UTF-8</param-value>
</init-param>
</filter>
<!-- 过滤器映射 -->
<filter-mapping>
<!-- 过滤器名称 -->
<filter-name>CharactorFilter</filter-name>
<!-- URL映射 -->
<url-pattern>/*</url-pattern>
</filter-mapping>
(4)从数据库取值乱码:比如mysql,确认你的数据库内字符是gbk,并且连接字符串指定了字符编码
<property name="url" value="jdbc:mysql://localhost/database?useUnicode=true&characterEncoding=gbk"></property>
(5)在action中直接使用request.getParameter()时;还是出现乱码。原因分析如下:
1、getParameter()是有带字符参数的。例:
String s =(String)request.getParameter("txt").getBytes("iso-8859-1");
2、String也可以带有字符参数。
String(byte[] bytes, String charsetName)
构造一个新的String,方法是使用指定的字符集解码指定的字节数组。
例:String s = new String("中文","utf-8");
3、综合上述两点,编写一个类来完成此项任务
public classConvertCharacter{
public String Convert(String s){
String result;
byte[] temp ;
try{
temp = s.getBytes("iso-8859-1");
result = new String(temp,"utf-8");
}
return result;
}
}
相关文章推荐
- struts2中文乱码问题的解决方法
- Struts2中文国际化乱码问题
- struts2 Annotation 实现文件下载功能 文件名中文乱码问题
- struts2 国际化 中文乱码英文不乱码问题
- struts2重定向时传递参数的实现!以及传递参数为中文时的乱码问题解决!
- struts2中文乱码问题的解决方法
- (Struts2解决篇)Struts2解决中文乱码问题
- 过滤器处理Struts2中文乱码的问题(struts2.1.3以后版本)
- Struts2文件上传完美解决中文乱码问题
- struts2解决中文乱码问题
- struts2 url 中文乱码问题解决方法
- Struts2中文国际化乱码问题
- SSH:Struts2的Action中获取GET请求参数中文乱码问题
- 如何处理struts2开发中的中文乱码问题
- 关于Json传递中文到struts2后台乱码问题
- struts2中文乱码问题
- JSP、Struts2下载中文文件名乱码问题
- struts2 action获取ajax提交数据中文乱码问题
- JSP、Struts2下载中文文件名乱码问题
- struts2解决文件上传下载中文乱码问题