读书人

ssh+mysql+jsp中文乱码有关问题

发布时间: 2012-04-16 16:20:04 作者: rapoo

ssh+mysql+jsp中文乱码问题

请求大家帮助,我遇到的问题是:

jsp页面提交的数据存到数据库是乱码
直接在数据库中插入中文的话也是乱码
显示在jsp页面的更是乱码了

我查了很多方法,可就是解决不了这个问题,麻烦大家帮忙一下,在此谢了

[解决办法]
jsp页面显示乱码是因为contenttype设置的问题
数据库中插入是乱码,是因为安装数据库时没有设置好,最好设置成UTF8
提交数据是乱码,需要过滤器,同时看看tomcat的server.xml配置文件 在<connector Port = 8080 的最 后加上URIEncoding="UTF-8"
[解决办法]

Java code
 <filter>      <filter-name>char</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>  </filter>  <filter-mapping>      <filter-name>char</filter-name>     <url-pattern>/*</url-pattern>  </filter-mapping>
[解决办法]
探讨
jsp页面显示乱码是因为contenttype设置的问题
数据库中插入是乱码,是因为安装数据库时没有设置好,最好设置成UTF8
提交数据是乱码,需要过滤器,同时看看tomcat的server.xml配置文件 在 <connector Port = 8080 的最  后加上URIEncoding="UTF-8"

[解决办法]
spring中有自带的字符过滤器
<filter>
<filter-name>Spring character encoding filter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
</filter>

另外 数据库编码自己改一下

[解决办法]
设置过滤器:

UnicodeFilter.java

package org.util;

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 UnicodeFilter implements Filter
{

String encoding="";

public void destroy()
{
// TODO Auto-generated method stub

}

/* (non-Javadoc)
* @see javax.servlet.Filter#init(javax.servlet.FilterConfig)
*/
public void init(FilterConfig config) throws ServletException {
encoding = config.getInitParameter("encoding");
if (org.apache.commons.lang.StringUtils.isEmpty(encoding))
{
encoding="UTF-8";
}
config.getServletContext().setAttribute("encoding", encoding);
}

/* (non-Javadoc)
* @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest,
* javax.servlet.ServletResponse,
* javax.servlet.FilterChain)
*/
public void doFilter(ServletRequest req, ServletResponse res,FilterChain chain)
throws IOException, ServletException
{
req.setCharacterEncoding(this.encoding);
chain.doFilter(req,res);
}

}


web.xml加:
<filter>
<description>UnicodeFilter</description>
<display-name>UnicodeFilter</display-name>
<filter-name>UnicodeFilter</filter-name>
<filter-class>org.util.UnicodeFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>UnicodeFilter</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>UnicodeFilter</filter-name>


<url-pattern>*.do</url-pattern>
</filter-mapping>

[解决办法]
同时在Action中处理页面数据时加上这样的一句话:request.setCharacterEncoding("UTF-8");
[解决办法]
1.url="jdbc:mysql://localhost:3306/mybase?autoReconnect=true&useUnicode=true&characterEncoding=UTF8"

characterEncoding设置成你的mysql的编码方式
2.指定当前数据表的 Character Set
3.保持request和response,filter编码一致
这问题好像好多人问
[解决办法]
安装数据库得时候选择得编码不对,
[解决办法]
老生长谈的问题啊
1.JSP页面设置为UTF-8
2.requset请求设置为UTF-8
3.如果是Tomcat 将Tomcat配置文件有个地方修改为UTF-8(网上有)
4.在mysql的链接上加上字符编码 这个最有用
5.过滤器
[解决办法]
中文乱码整体说来就是你的各个应用层没有使用统一的编码所造成的

[解决办法]
总的来说就是在所有可以设置编码方式的地方
都是用同一种编码,最好是用UTF-8

具体的情况有:
1、JSP设置UTF-8
2、框架内部定义过滤器
3、数据库的设置

mysql在安装时可以设置编码方式

如果按照上述要点进行设置,乱麻可以解决。
[解决办法]
我也遇见过这个问题是你驱动中需要预加载连接MYSQL的编码格式jdbc:mysql://127.0.0.1:3306/数据库名?useUnlcode=1&characterEncoding=gbk这样就可以了
[解决办法]
直接把服务器的编码方式改成utf-8 的 试试
[解决办法]
在mysql命令下输入
show variables like '%char%';
查看mysql 字符集设置情况
在查询结果中可以看到mysql 数据库系统中客户端、数据库连接、数据库、文件系统、查询
结果、服务器、系统的字符集设置
在这里,文件系统字符集是固定的,系统、服务器的字符集在安装时确定,与乱码问题无关
乱码的问题与客户端、数据库连接、数据库、查询结果的字符集设置有关,可以通过下面命令设置:
set character_set_client = 字符集
set character_set_connection = 字符集
set character_set_results = 字符集

再接下来就就是
连接URL=jdbc:mysql://localhost:3306/abs?useUnicode=true&characterEncoding=字符集

还有就是配置过滤器
JSP 页面等终端也要设置相应的字符集

读书人网 >Java Web开发

热点推荐