开发者社区> 行者武松> 正文

开发过程遇到的中文乱码问题如何解决

简介:
+关注继续查看

1.数据库编码不一致导致乱码

解决方法:

首先查看数据库编码,输入:


  1. show variables like "%char%"

开发过程遇到的中文乱码问题如何解决

确认编码一致,如果不一致,可输入:


  1. SET character_set_client='utf8'
  2. SET character_set_connection='utf8'
  3. SET character_set_results='utf8'

也可设置成gbk编码;

也可以在安装Mysql目录下修改my.ini文件


  1. default-character-set=utf-8 

2.jsp页面乱码问题

在myeclipse中jsp的默认编码为ISO-8859-8;

只需在页面头部修改为


  1. <%@page pageEncoding="UTF-8" contentType="text/html; charset=UTF-8" %> 

在JSP页面头部加入下面这句话,告诉浏览器应该调用UTF-8的字符集。


  1. <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>   

3.jsp连接数据库存入中文乱码

在数据库连接时


  1. jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8 

如果使用框架连接则把头文件都修改成UTF-8编码即可

4.在使用struts2可使用过滤器:

先变写一个过滤器


  1. package com.oumyye.util; 
  2.  
  3. import java.io.IOException; 
  4.  
  5. import javax.servlet.Filter; 
  6. import javax.servlet.FilterChain; 
  7. import javax.servlet.FilterConfig; 
  8. import javax.servlet.ServletException; 
  9. import javax.servlet.ServletRequest; 
  10. import javax.servlet.ServletResponse; 
  11.  
  12. public class CharacterEncodingFilter implements Filter{ 
  13.  
  14.     protected String encoding = null
  15.     protected FilterConfig filterConfig = null
  16.  
  17.     public void init(FilterConfig filterConfig) throws ServletException { 
  18.         this.filterConfig = filterConfig; 
  19.         this.encoding = filterConfig.getInitParameter("encoding"); } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { if (encoding != null) { request.setCharacterEncoding(encoding); response.setContentType("text/html; charset="+encoding); } chain.doFilter(request, response); } public void destroy() { this.encoding = nullthis.filterConfig = null
  20.     } 

在web.xml中配置


  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"
  3.   <display-name>0001web</display-name> 
  4.   <!-- 中文编码过滤器 --> 
  5.     <filter> 
  6.         <filter-name>CharacterEncodingFilter</filter-name> 
  7.         <filter-class>com.oumyye.util.CharacterEncodingFilter</filter-class
  8.         <init-param> 
  9.             <param-name>encoding</param-name> 
  10.             <param-value>UTF-8</param-value> 
  11.         </init-param> 
  12.     </filter> 
  13.     <filter-mapping> 
  14.         <filter-name>CharacterEncodingFilter</filter-name> 
  15.         <url-pattern>/*</url-pattern> 
  16.         <dispatcher>REQUEST</dispatcher> 
  17.         <dispatcher>FORWARD</dispatcher> 
  18.     </filter-mapping> 

在表单中只能使用post传值,此方法对于get无效。

5 处理单个字符串的中文乱码问题


  1. String newnewname=new String(name.getBytes("iso-8859-1"),"utf-8")) 

附:JSP中的编码设置

1. pageEncoding:<%@ page pageEncoding="UTF-8"%>

设置JSP编译成Servlet时使用的编码  

2. contentType: <%@ page contentType="text/html; charset=UTF-8"%>

对服务器响应进行重新编码,即jsp的输出流在浏览器中显示的编码

3. html页面charset:<META http-equiv="Content-Type" content="text/html; charset=UTF-8">

网页的编码信息 ,说明页面制作所使用的编码

4. request.setCharacterEncoding()  -- 可用在servlet和jsp页面中

作用是设置对客户端请求进行重新编码的编码,即post方式提交的数据进行编码。

5. response.setCharacterEncoding() -- 可用在servlet和jsp页面中

对服务器响应进行重新编码,即jsp的输出流在浏览器中显示的编码,与<%@ page contentType="text/html;charset=UTF-8"%>一样

6. response.setContentType() -- 可用在servlet和jsp页面中

对服务器响应进行重新编码,即jsp的输出流在浏览器中显示的编码,与<%@ page contentType="text/html;charset=UTF-8"%>一样 

7.response.setHeader("Content-Type","text/html;charset=UTF-8");   -- 可用在servlet和jsp页面中

与<META http-equiv="Content-Type" content="text/html; charset=UTF-8">一样


作者:偶my耶

来源:51CTO

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
ECS使用体验
在阿里云领取了一个服务器,分享一下使用体验
5 0
ECS使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
3 0
使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
3 0
ECS使用感受
阿里云服务器初体验
4 0
ECS使用感受
阿里云服务器初体验
3 0
ECS使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
4 0
postgressql简单配置
postgresql.conf 和 pg_hba.conf 文件
3 0
+关注
行者武松
杀人者,打虎武松也。
17142
文章
2569
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载