当前位置:文档之家› 基于范例分析的JSP中文乱码解决方案

基于范例分析的JSP中文乱码解决方案

基于范例分析的JSP中文乱码解决方案
基于范例分析的JSP中文乱码解决方案

Computer Knowledge and Technology 电脑知识

与技术第5卷第26期(2009年9月)基于范例分析的JSP 中文乱码解决方案

刘步星,周赛

(长沙电力职业技术学院,湖南长沙410131)

摘要:中文乱码是JSP 动态网站开发过程中经常遇到的问题,该文从产生JSP 中文乱码的范例入手,分析了产生乱码的原因,给出了消除乱码的具体方法,具有实用性和易操作性。

关键词:JSP ;编码;乱码;解决办法

中图分类号:TP311文献标识码:A 文章编号:1009-3044(2009)26-7426-02

Solution of Chinese Messy Code in JSP Based on Sample Analysis

LIU Bu-xing ,ZHOU Sai

(Changsha Electric Power Technical College,Changsha 410131,China)

Abstract:Chinese characters messy code is problem that we often encountered with in Dynamic web development process.This article start with an analysis of the reasons for messy code from the generated JSP messy code examples and give the elimination of the specific method is practical and easy operability.

Key words:JSP;coding;mess code;solving method

JSP 是目前流行的一种动态网站的开发技术,它强大的跨平台的动态网页设计能力受到我国众多程序开发人员的青睐。然而在基于JSP 技术的动态网站开发过程中,由于操作系统、浏览器及数据库所使用的编码方式各异,对中文的支持也不尽相同,如果处理不当,便会出现中文乱码,使开发人员不知所措。

JSP 中出现的中文乱码主要可以归结为四种类型:页面乱码、表单传递过程中出现的乱码、读数据库出现乱码和写数据库出现乱码。本文针对这四种类型,设计了尽可能简单又不失一般性的范例,进而分析乱码产生的原因,给出消除乱码的具体方法。

本文的测试环境为:Apache Tomcat 5.5、mysql-4.0.25-win 、Navicat 8for MySQL 。如果使用更高版本的mysql ,则在安装过程中,要将字符集Character Set 设为:gb2312(或gbk ),并在Navicat 8for MySQL 中作应用的设置。

1JSP 页面中文显示出现乱码的处理

【范例设计】hello.jsp ,网页的全部代码于下:

我的第一个JSP 网页

<%out.print("你好,JSP!");%>

该网页代码的本意是设计一个标题为“我的第一个JSP 网页”、显示内容为“你好,

JSP!”的JSP 网页。但除了英文能正常显示外,所有的中文都成了乱码,如图1所示。

【问题分析】JSP 采用ISO-8859-1作为默认的页面字符编码,这是一种定长单字节字符集,适用于拉丁语,又称Latin-1,不能识别中文。

【解决办法】在网页代码中,加载页面指令

<%@page contentType="text/html;charset=gb2312"language="java"%>

这就规定了jsp 按其后指定的中文字符集gb2312编码输出到页面(gb2312改为GBK 也可以,前者是后者的一个子集,在本文的讨论中,可以不加区别地通用)。

【测试结果】添加了上述页面指令后,再刷新网页hello.jsp ,网页标题及内容都正确地显示了相应的中文信息。

说明:如果用Dreamweaver 8来编写JSP 网页,上述类似的页面指令会默认加载。可以避免出现这种乱码。

2表单传递过程中乱码的处理

【范例设计】reply.jsp

<%@page contentType="text/html;charset=gb2312"language="java"%>

表单传送数据

收稿日期:2009-06-23

作者简介:刘步星(1955-),男,副教授,主要研究方向为电子商务、动态网站设计。

图1页面出现中文乱码ISSN 1009-3044Computer Knowledge and Technology 电脑知识与技术Vol.5,No.26,September 2009,pp.7426-7427,7431E-mail:xsjl@https://www.doczj.com/doc/a09578162.html, https://www.doczj.com/doc/a09578162.html, Tel:+86-551-56909635690964

请输入用户名:

<%String name=request.getParameter("textfield");out.print("您的用户名是:"+name);%>

本例含一个由文本框和一个提交按钮组成的表单,用户在文本框输入信息并

按下提交按钮向服务器提交信息后,服务器立刻将该用户信息返回。如果用户提交

的是英文信息,得到的是正确的返回信息;如果提交的是中文信息,返回的却是乱码。图2,是当用户输入“大学生”后返回的乱码。

【问题分析】由Request.getParameter()得到的参数,编码方式都是ISO8859_1,直接按这种编码方法显示中文必然得到乱码。

【解决办法】

方法一:

在标记之前,加上一句:<%request.setCharacterEncoding("GBK");%>

则对于该网页中所有request.getParameter()语句有效。

方法二:

在配置文件server.xml 中,找到含port="8080"的Connector 区块,在其后加一句:URIEncoding="GBK"。修改后的完整信息如下:

port="8080"maxHttpHeaderSize="8192"

maxThreads="150"minSpareThreads="25"maxSpareThreads="75"

enableLookups="false"redirectPort="8443"acceptCount="100"

connectionTimeout="20000"disableUploadTimeout="true"/URIEncoding="GBk">

重启Tomcat 后就OK 了。

此法虽比方法一稍微麻烦一点,但它对网站中所有网页中的request.getParameter()语句有效,可以说是“一劳永逸”。

【测试结果】按方法一或方法二处理后,再在reply.jsp 的表单中输入中文信息,则在下行回显相同的中文信息。这说明表单已经能够正确地传递中文信息了。

3读MySQL 数据库中文信息出现乱码的处理

【范例设计】

1)创建数据库sqltest 及表names ,表names 只有两个字段(IP 为主键,自动递

增),两条记录(其中一条存放有中文字符)。如表1所示。

2)建立一个JSP 动态网页show.jsp ,按常规方式将表name 在该网页中以动态

表格的形式显示出来,结果是英文信息“zhan san ”显示正确,而中文信息“李四”成

了乱码,如图3。

【问题分析】数据库的JDBC 驱动程序,默认的在Java 程序和数据库之间传递

数据都是以ISO-8859-1为默认编码格式的,即使数据库原本就是用中文编码(如

GBK )格式保存数据的,JDBC 也会自作主张地将其转换为ISO-8859-1编码格式,

从而导致乱码。

【解决办法】连接数据库时,在url 后面加上“?useUnicode=true&characterEn -

coding=GBK ”

在本例中,原url 为:jdbc:mysql://localhost:3306/sqltest 。

修改后,成为:jdbc:mysql://localhost:3306/sqltest?useUnicode=true&characterEn -coding=GBK

【测试结果】从浏览器端再次访问(或刷新)show.jsp ,可见中文信息得到正确

显示。

4写MySQL 数据库时中文信息出现乱码的处理

【范例设计】

在Dreamweaver 中建立一个网页insert.jsp ,它含一个由文本框和一个提交按

钮组成的表单,通过加入服务器行为———插入记录,使它具有向上述数据表names

插入记录,并转向能正确显示含中文记录show.jsp 的功能。这样我们就可以通过

insert.jsp 插入记录,并由show.jsp 显示结果了。不幸的是当插入中文后,显示的结

果却是乱码。如图4、图5所示,输入“张三”后,显示的却是????。(也可以直接从数

据库中证实,保存到表name 中的确实是乱码。)

【问题分析】如前所述,数据库的JDBC 驱动程序在Java 程序和数据库之间传

递数据都是以ISO8859-1为默认编码格式的,程序在向数据库内存储包含中文的(下转第7431页)

图2表单提交中文信息,返回的却是乱码表1names 数据表图3读数据库出现中文乱码

图4通过表单向数据表插入含中文信息的记录图5插入到数据表的中文记录成了乱码

行自动化测试,节约大量的手工测试的时间;

5)测试人员不需要知道测试工具实现的细节,只需要和表打交道和执行自动化脚本;

6)配置项从脚本中分离使得易于实现平台的转换,测试的移植。

4工作总结

本文中主要介绍了自动化软件测试技术,核心部分在于提出应用软件自动化测试框架实现软件自动化测试。以某软件作为应用背景提出一个适合该软件自动化测试的基于关键字和数据驱动的自动化测试框架。并将该框架模型应用于软件开发过程中的软件自动化测试。

这是一个最新的也是比较热门的发展方向。自动化测试中的自动化测试框架的研究也称为一个新的发展趋势。

现在,己经有一些商业化的自动化测试框架。在大多数情况下,他们和已有的商业化测试工具捆绑在一起。他们的主要不同点在于他们的底层的执行引擎或脚本库,是被映射到关键字,窗口还是对象或类,这也是将来自动化测试框架发展的几个趋势。关键字驱动的测试引擎已经实现,接下来,窗口引擎,对象引擎和类引擎等底层引擎的实现将会是商业化自动化测试框架的主要研究方向。

参考文献:

[1]Pressman R S.软件工程实践者的研究方法[M].北京:机械工业出版社,2002.

[2]Berard E V.Essay on Object-Oriented SoftWare Engineering[M].Addison Wesley,1993.

[3]Zeyu J,Gao H S,Tsao J,et al.Testing and Quality Assurance for Component-Based Software[M].London:Artech House,2003.

[4]Dustin E.软件自动化测试:引入,管理大与实施[M].于秀山,胡兢玉,译.北京:电子工业出版社,2003.

[5]严少清,陈革,万年红.软件测试自动化管理系统的设计与实现[J].计算机工程,2002,28(9):152-154.

[6]Beydeda S,Gruhn V.State of the art in testing components[C].Dallas,TX,USA:Proc of the3rd International Conference on Quality Soft-

ware,2003.

[7]Maurer P M.The design and implementation of a grammar-based data generator[J].Software Practice&Experiencies,1992,23(3):233-

244.

[8]冯玉才,唐艳,周淳.关键字驱动自动化测试的原理和实现[J].计算机应用,2004(7).

[9]金大海.数据驱动自动化测试方法研究[J].装甲兵工程学院学报,2004(2).

[10]Wang Y X,King G,Wickburg H.A method for Built-in Tests in Component-based Software Maintenance[C].Amsterdam,Netherlands:

Proceedings of the Third European Conference on Software Maintenance and Reengineering,1999.

[11]Dustin E.软件自动化测试:引入、管理与实施[M].北京:电子工业出版社,2003.

(上接第7427页)

数据前,JDBC首先是把程序内部的Unicode编码格式的数据转化为ISO8859-1的格式,然后传递到数据库中,从而导致写入数据库的中文信息变成了乱码。

【解决办法】赶在ISO-8859-1的格式编码数据写入数据库之前,将这些数据换成中文编码格式。

具体操作是:查找注释“//finish the sql and execute it”,将其下第三句(也就是执行写数据库操作的前一句):

PreparedStatement MM_editStatement=MM_connection.prepareStatement(MM_editQuery.toString());

改为两句:

String newstr=new String(MM_editQuery.toString().getBytes("8859_1"),"GBK");

PreparedStatement MM_editStatement=MM_connection.prepareStatement(newstr);

【测试结果】再通过网页insert.jsp插入一条中文记录,show.jsp则正确地将该记录显示出来,此结果表明insert.jsp确实将中文信息正确写入到数据库。

说明:笔者发现,当用Dreamweaver来编辑JSP动态网页时,凡是涉及写数据库操作,要改的都是本例所指的那句,因此本例具有一般通用意义。

4结束语

在基于JSP技术的动态网站开发过程中,不可避免地要字符的编码问题打交道。为了消除出现的乱码,可以有目的地在输入/输出环节中增加必要的转码。其次,由于各种服务器有不同的处理方式,还需要多做试验,确保使用中不出现乱码。

参考文献:

[1]陈小瀚.中文编码原理及其乱码问题的探讨[J].科技信息:科学教研,2007(24).

[2]李国禄.JSP中文乱码问题分析及处理方法[J].甘肃联合大学学报:自然科学版,2007(6).

[3]伍德雁.Tomcat应用系统乱码问题研究[J].电脑知识与技术,2008(22).

[4]蒋军强.MySQL数据库中乱码成因及解决办法探究[J].科技信息:科学教研,2009(33).

jsp读取数据库中文乱码问题

jsp读取数据库中文乱码问题 这个问题是从项目中设计数据库和操作数据库的人不同而造成的。所用的数据库 是sybase,设计时把数据类型设计为nvarchar了,如果是中文,读取出来就会得到乱码。我试了好多方法还是不行,最后无奈,只好将数据类型改为varchar了。所以在此总结一下中文乱码问题。 一、JSP与页面参数之间的乱码 JSP获取页面参数时一般采用系统默认的编码方式,如果页面参数的编码 类型和系统默认的编码类型不一致,很可能就会出现乱码。解决这类乱码问题的 基本方法是在页面获取参数之前,强制指定request获取参数的编码方式:request.setCharacterEncoding("GBK")或request.setCharacterEncoding ("gb2312")。 如果在JSP将变量输出到页面时出现了乱码,可以通过设置 response.setContentType("text/html;charset=GBK")或 response.setContentType("text/html;charset=gb2312")解决。 二、Java与数据库之间的乱码 大部分数据库都支持以unicode编码方式,所以解决Java与数据库之间的 乱码问题比较明智的方式是直接使用unicode编码与数据库交互。很多数据库驱动自动支持unicode,如Microsoft的SQLServer驱动。其他大部分数据库驱动,可以在驱动的url参数中指定,如如mm的mysql驱动: jdbc:mysql://localhost/WEBCLDB?useUnicode=true&characterEncoding=GBK。 三、Java与文件/流之间的乱码 Java读写文件最常用的类是FileInputStream/FileOutputStream和FileReader/FileWriter。其中FileInputStream和FileOutputStream是基于字节 流的,常用于读写二进制文件。读写字符文件建议使用基于字符的FileReader和

中文乱码解决大全

SSH开发过程中的中文问题汇总 作者:Rainisic来源:博客园发布时间:2012-01-11 14:26 阅读:50 次原文链接[收藏] 在使用SSH开发的过程中,我们经常会因为各种各样的中文乱码问题而苦恼。之前开发的过程中遇到过一些,但是都没有记录下来,这次,我就遇到的中文问题进行一个汇总,希望能够对大家有所帮助。 1. 平台环境参数 操作系统:Windows 7 旗舰版64位 JDK版本:JDK 1.6 / JDK 1.7 (此处由于JDK 7 发布不久,所以对两个版本进行测试) 开发环境:Eclipse Java EE Indigo 网站容器:Tomcat 7.0 开发框架: Struts 2.3.1.1-GA Spring 3.1.0-release Hibernate 4.0.0-Final / Hibernate 3.6.9-Final (此处由于Hibernate 4 final 刚刚发布不久,所以对两个版本进行测试) 2. 中文问题汇总 (1)HTML中未指定文件编码 问题描述:在HTML中未指定文件编码,在部分浏览器中将会出现中文乱码。 解决方案:在HTML的head标签中指定文档编码,代码如下(请根据DOCTYPE选择): // HTML 4.01 Transitional

// HTML 5 (2)表单提交使用GET方法 问题描述:在HTML form 中提交表单的时候使用method="get"导致中文乱码。 解决方案:form表单的method设置为post,代码如下:

(3)JSP文件中未指定文档编码类型 问题描述:在JSP文件中未指定JSP文档编码,在浏览器中会出现中文乱码。 解决方案:在JSP文件首部增加指定文档编码的代码,代码如下: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> (4)文件编码不正确 问题描述:由于Java文件、JSP文件等文件编码不正确,导致中文乱码。 解决方案:设置文件的默认编码为UTF-8(如果需要使用其他编码,请确保上述两个编码格式与文件编码相同) 设置方法: 当前文件编码修改:该文件右键→Properties→Resource,右侧Text file encoding→Other →UTF-8 默认文件编码修改: 0. Windows→Preferences 打开Eclipse配置选项窗口。 1. General→Content Type,右侧Text 下面所需要的文件类型Default encoding设置为UTF-8

jsp乱码问题全部解决

Jsp乱码问题 Eclipse中源码的中文部分都显示成乱码 1(1)右键点击你的工程,选择Properties,打开面板后,选择Resource,将Test file encoding 项中选择Others,再选择UTF-8 (2)右键你的项目,选择属性,在里面进行设置。 编码,最好设置成UTF-8的,因为它的兼容性最好。 (3)eclipse 首选项中设你要的编码-也就是你说的那个空间要用的是什么字符编码 还有一个就是JSP的<%@ contenteType="text/html;charset=utf-8" page %>里面有二个 指定文件的编码。我用的是英文版的Eclipse,现在就用英文版来说明这个过程。 打开菜单–Window–Preferences–General–Content Types,展开右边Text旁的加号,向下查找到”Java Source File”, 2.乱码解决方法: 1.web服务器的编码设置 server.xml //你也可以写一个过滤器 request.setCharacterEncding("utf-8") response.setCharacterEncding("utf-8") 2.取参数时设置编码 request.setCharacterEncoding("utf-8"); 3.对字符串进行强制转码 String name = request.getParameter("name"); name = new String(name.getBytes("is0-8859-1"),"utf-8"); 4.源代码里的编码方式 a.设置项目属性,使它的编码方式与文件编码方式相同。 b.设置文件属性,使它的编码方式与文件编码方式相同。 还有数据库中,和数据库连接时也要设。。 回答者:qqgg123kk | 二级| 2011-3-5 14:52 <%@page language="java"contentType="text/html; charset=gb2312" pageEncoding="utf-8"import="java.util.Date"%> 打开菜单–Window–Preferences–General–Content Types JAVABEAN使用

JSP中文乱码的产生原因及解决方案

JSP中文乱码的产生原因及解决方案 在JSP的开发过程中,经常出现中文乱码的问题,可能一直困扰着大家,现在把JSP 开发中遇到的中文乱码的问题及解决办法写出来供大家参考。首先需要了解一下Java中文问题的由来: Java的内核和class文件是基于unicode的,这使Java程序具有良好的跨平台性,但也带来了一些中文乱码问题的麻烦。原因主要有两方面,Java和JSP文件本身编译时产生的乱码问题和Java程序于其他媒介交互产生的乱码问题。首先Java(包括JSP)源文件中很可能包含有中文,而Java和JSP源文件的保存方式是基于字节流的,如果Java和JSP编译成class文件过程中,使用的编码方式与源文件的编码不一致,就会出现乱码。基于这种乱码,建议在Java文件中尽量不要写中文(注释部分不参与编译,写中文没关系),如果必须写的话,尽量手动带参数-ecoding GBK或-ecoding gb2312或-ecoding UTF-8编译;对于JSP,在文件头加上<%@ page contentType="text/html;charset=GBK"%>或 <%@ page contentType="text/html;charset=gb2312"%>基本上就能解决这类乱码问题。 下面是一些常见中文乱码问题的解决方法(下面例子中ecoding采用的是gb2312,也可设为ecoding GBK或ecoding UTF-8): 一、 JSP页面乱码 这种乱码问题比较简单,一般是页面编码不一致导致的乱码,一般新手容易出现这样的问题,具体分以下两种情况: 未指定使用字符集编码 下面的显示页面(display.jsp)就出现乱码: JSP的中文处理 <%out.print("JSP的中文处理");%>

jsp页面传值中文乱码 网页乱码 jsp过滤器过滤乱码等乱码处理办法

一、jsp页面间传值中文乱码问题解决办法 <%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>

name:
b.jsp页面内容: <%@ page language="java" import="java.util.*" pageEncoding="GB2312"%> <% String name=request.getParameter("name"); %> <%=name%> 现象:中文乱码,比如“??????” 解决方法如下: 方法一: 1. 在b.jsp中把pageEncoding="GB2312"改为 pageEncoding="ISO885Array-1" 虽然这样b.jsp页面显示的内容还是乱码,但是不是那种“??????”的乱码,而是一些特殊字符 2. 然后在浏览器中查看菜单中修改成GB2312的编码,这时乱码就显示中文了。 3. 但是这种方法是不可行的。 方法二:( 已经验证可行) 1. 在b.jsp中把String name=request.getParameter("name");修改为 String name=new String(request.getParameter("name").getBytes("ISO-885 Array-1"),"GB2312"); 2. 这时再在页面上显示,则就是中文了。 方法三:

cmd窗口显示中文乱码及无法输入中文解决方法

cmd窗口显示中文乱码及无法输入中文解决方法 (2009-05-09 19:13:12) 分类:软件应用 标签: it 中文显示为乱码 临时解决方案: 在 CMD 中运行 chcp 936。 永久解决方案: 打开不正常的 CMD 或命令提示符窗口后,单击窗口左上角的图标,选择弹出的菜单中的“默认值”,打开如下图的对话框。单击第一个“选项”选项卡,将默认的代码页改为 936 后重启 CMD。 附:

如果改了以后无法生效,窗口的“默认值”和“属性”没变,进入注册表,在 HKEY_CURRENT_USER 下找到 console 项下的 Console 以及其下可能有 的 %SystemRoot%_system32_cmd.exe(这个 %SystemRoot%_system32_cmd.exe 下有的 codepage 话就改,如果没有就不管它),codepage值改为 936(十进制)或 3a8(十六进制)。 936(十进制)/3a8(十六进制) 是简体中文的,如是其它语言,要改为对应的代码。然后再执行第二段中所述的操作。 还可能和 CMD 的默认值的“字体”设置有关。 在 CMD 的“默认值”和“属性”的“字体”选项卡中中确认设定的字体是可以显示中文字符的字体,并且确定字体文件没有被破坏。字体最好设置为默认的点阵字体。 还是不行,干脆把%SystemRoot%_system32_cmd.exe内容备份下,然后清空它。或是把以下内容保存为REG文件导入试试。 Windows Registry Editor Version 5.00 [HKEY_CURRENT_USER\Console\%SystemRoot%_system32_cmd.exe] "QuickEdit"=dword:00000800 "CodePage"=dword:000003a8 "WindowSize"=dword:001e005a "FontSize"=dword:000c0008 "FontFamily"=dword:00000030 "FontWeight"=dword:00000190 "FaceName"="Terminal" ============================================================= 无法输入中文 确认以下事项: 1.CMD 里中文字符可以正常显示(上文). 2.注册表中 HKEY_CURRENT_USER\Console 及 HKEY_CURRENT_USER\Console\%SystemRoot%_system32_cmd.exe] 下LoadConIme 的值为 1. 3.conime.exe 这个文件存在,没有受到破坏,并且正常运行.

win7系统常见的乱码问题解决方法

win7系统常见的乱码问题解决方法 win7系统乱码的问题,经常会碰到一些软件是简体中文的,可是在win7系统中却出来乱码的问题?400pc小编教你破解是哪些原因造成win7系统乱码。 近期,居住香港的姐姐也安装了Windows 7,不过,令她烦恼的是使用一些简体中文的软件出现了乱码。而这些软件都无法找到繁体版本,比如:迅雷,即使勉强安装好也无法轻松使用。难道香港用户就无法使用这些简体软件了吗?其实,Windows 7自身已经提供了完善的解决方案了。 一、Windows 7乱码问题来龙去脉 旅居香港的姐姐安装的是我提供的简体中文版本的Windows 7旗舰版,按理是可以顺利兼容简体软件的,然而问题就出在姐姐对默认的安装设置进行了修改。因为姐姐经常使用繁体软件,她将系统的“区域和语言”的“格式”、“位置”、“默认输入语言”、“非Unicode程序的语言”都设置成了更加顺手的香港繁体。 我们知道Unicode也可称为统一码,为每种语言的每个字符设置了统一且唯一的二进制编码,以满足跨语言、跨平台进行文本转换处理的要求,然而,还是有不少程序并不支持该编码,这时就有必要设置非Unicode程序使用的语言编码了。像迅雷这样的软件就支持简体中文编码,而不支持Unicode,当设置了香港繁体的非Unicode 就会出现乱码,同理,将非Unicode设置为简体后,很多不支持Unicode的繁体软件也会出现乱码。这个乱码问题难道是两难的吗?其实,我们使用Windows 7的语言包补丁安装功能就可以顺利解决。 二、巧妙解决Windows 7乱码 1.安装合适的语言包 首先,要能安装多种语言包的Windows 7只能是旗舰版或者企业版,接着我们就来解决这个问题吧。我们点击“开始-Windows Update”打开自动更新窗口。 在窗口中点击“34个可选更新”链接,在可以下载安装的语言包列表中选择“繁体中文语言包”,确定即可。 回到刚才的窗口点击“安装更新”按钮开始下载安装。 安装完语言包补丁需要重启。重启的过程需要配置补丁。

jspjava乱码解决

中文乱码总结: 1-->响应中的乱码: 单个页面中,如果出现中文(注意不是post中文也不是get中文,只是显示中文而已),而且使用的是 <%@page contentType="text/html;charset=iso-8859-1"%> 此时显示的 中文就是乱码,为什么呢? 因为charset=iso-8859-1 是设置http的响应(response)中的编码信息,因为是中文,所以http给浏览器显示的 汉字是乱码。 2-->post乱码: 两个页面(或多个页面)通过form表单post传值(form的默认提交方式都是GET)时,这里与1不同,为什么呢? 因为此时发送了请求有request,而1中没有request只是响应而已。发送请求的时候,使用的编码默认的是iso-8859-1, 意味着只有英文是有效字符,这个限制是因为当初指定http标准的成员都来自英语国家,所以如果使用默认的方式 从请求获取数据,中文一定会全部变成乱码。此时就要加上 request.setCharacterEncoding("gbk");有了 请求request.setCharacerEncoding("gbk")编码方式和http的响应(response)中的编码信息 <%@pagecontentType="text/html;charset=gbk"%> 两个都gbk,此时body中的(注意是body,如果是url就会有问题往下看就知道了)中文就不会显示为乱码 a---乱码出现的过程是这样的,传的是汉字,发送请求的默认编码是 iso-8859-1,此时把汉字按iso-8859-1转码出现问题出现??或莫名的符号,响应的时候位数都打乱了(iso-8859-1和gbk编码位数不一样),虽然 <%@pagecontentType="text/html;charset=gbk"%>但还是会出现乱码。 b---而采用request.setCharacerEncoding("gbk")设置请求编码后的话,汉字就不会被转成乱码。 3-->get乱码 POST方式下的解决方式还算简单,因为POST方式下提交的数据都是以二进制的方式附加在http请求的body部分发送, 只需要在后台指定编码格式就足矣解决。 GET方式下会将参数直接附加到url后面,这部分参数无法使用 request.setCharacterEncoding()处理,结果就是get形式的所有中文都变成了乱码

Android读取中文文件乱码解决方法

最近在做个MP3播放器,出现中文乱码问题,在网上找了很多解决办法,我整理了出现乱码的点和解决方案,拿出来和大家共享一下 1.读取中文文件乱码解决方法 package com.apj.conv; import java.io.BufferedInputStream; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStreamReader; import android.app.Activity; import android.os.Bundle; import android.os.Environment; import android.widget.TextView; public class ConverActivity extends Activity { private TextV iew textview ; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(https://www.doczj.com/doc/a09578162.html,yout.main); textview = (TextView) findView ById(R.id.lrctext); System.out.println("==============convertCodeAndGetText begin============== ") ; ///获得SDCard中文件的路径 String path = Environment.getExternalStorageDirectory().getAbsolutePath()+ File.separator ; String tochinese = convertCodeAndGetText(path+"a.txt"); System.out.println(tochinese); System.out.println("==============cconvertCodeAndGetText end=============="); textview.setText(tochinese); }

jsp文件调用js时,js文件中文字乱码

register.jsp checkreg.js function check(myform){ if(myform.email.value==""){ alert("test请输入Email地址!");myform.email.focus();return (false); } if(!checkemail(myform.email.value)){ alert("您输入Email地址不正确!");myform.email.focus();return (false); } } JSP文件调用外部js文件时,alert出来的对话框中中文是乱码! 解决方案:将js文件在UltraEdit等软件中,另存为utf-8编码格式,再复制到工程中 总结: 许多乱码情况都是两个文件编码格式不统一造成的,所以将两个文件的编码格式统一是解决乱码问题的一个指导思想! 1、在JS里对中文参数进行两次转码 复制代码代码如下: var login_name = document.getElementById("loginname").value; login_name = encodeURI(login_name); login_name = encodeURI(login_name); var aMsg = [ "很不满意|与人们描述的严重不符,非常不满", "不满意|部分有与人们描述的不符,不满意", "一般|一般,没有人们描述的那么好", "满意|不错,与人们描述的基本一致,还是挺满意的", "非常满意|与人们描述的完全一致,非常满意" ]; aMsg = encodeURI(aMsg); aMsg = encodeURI(aMsg);

关于Linux下中文乱码的完整解决方案

关于Linux下中文显示为乱码的完整解决方案Linux,作为一款免费的操作系统,相对于高额费用的Windows系列操作系统,有着更强的优势,所以,许多人也都开始学习Linux操作系统的知识。但是,由于Windows 系列操作系统还是当今社会的主流,所以,人们少不了在Windows和Linux系统之间进行文件的传输。 但是一个新问题出现了,那就是中文乱码问题,这个问题困扰着无数的Linux用户,尤其是Linux的初学者,对于这个问题相当的头疼。 主要问题如下: 1、ssh中,中文显示为乱码:在Wind ows 系统下,用ssh远程连接Linux系统,对于在Linux下显示正常的中文,在ssh中却显示为完全无法识别的乱码字符。 2、中文传输乱码:把Wind ows中的中文文件传输到Linux操作系统中,原本在Wind ows下显示正常的文件,到了Linux系统下,成了无法识别的乱码。 分析其原因,是因为Linux和Wind ows系统下,所用户的字符集不同,Linux系统使用的是Unicod e字符集,而Wind ows使用的是GB字符集。所以,在网上出现了两种解决方案: 方法一:使用Putty代替secure shell client(ssh):在Putty终端设置中,修改wind ow-〉Translation中的Received data assumed to be in which character set值为Linux 中的字符集UTF-8,再连接Linux,

发现这时,Linux中的中文可以正常显示了。 但是一个新问题出现了,把Wind ows中的文件上传了Linux 中,原本在Wind ows下显示正常的中文文件,现在却成了乱码。 所以,这个方法无法彻底解决乱码问题。 方法二:修改Linux默认字符集,把Linux的默认字符集修改为和Wind ows中的字符集一致的GB18030或GB2312,重启Linux系统后,再用ssh终端连接,这时,修改字符集后的中文文件都已经能正常显示,而且,从Wind ows中新上传的中文文件也能正常显示了。这个方法不错。 但是,Linux系统在安装时,产生的中文字符(中文文件夹名、中文文件名、中文文件)在新的字符集下,却又全都显示成了乱码。 有什么方法可以彻底解决乱码问题,使在Linux系统下,所有的中文字符都可以正常显示呢? 本人综合了网上的各种解决方案,经过多次实验,终于找到了一个比较完整的解决方案,步骤如下: 第一步:用英文安装Linux系统:在安装Linux系统时,采用默认的英文安装,而不要使用中文。 第二步:修改字符集:在Linux系统安装成功以后,修改系统的默认字符集,操作如下: 在Fedora Linux系统中,编辑/etc/sysconfig/i18n文件,修改LANG 值为zh_CN.GB2312或zh_CN.GB18030,保存退出。 在OpenSuSE Linux系统中,编辑/etc/sysconfig/language文件,

有关JSP和数据库乱码问题的处理方式

JSP乱码终极解决方案(2)2008-09-27 01:53 A.M 2,具体说来,需要哪些信息才能确定项目中的乱码的根源. a,开发者所用的操作系统 b,j2ee容器的名称,版本 c,数据库的名称,版本(精确版本)以及jdbc驱动的版本 d,出现乱码的source code(比如是system out 出来的,还是jsp页面中的,如果是jsp中的,那么头 部声明的情况也很重要) 3,如何初步分析乱码出现的原因. 有了上述的信息,基本上就可以发帖求助了,相信放到javaworld等论坛上,很快就会有高手给你提出 有效的解决方案的. 当然不能总靠发帖求助,也要试试自行解决问题.如何下手呢? a,分析一下你的"乱码"到底是什么编码.这个其实不难,比如 System.out.println(testString); 这一段出现了乱码,那么不妨用穷举法猜测一下它的实际编码格式. System.out.println(new String(testString.getBytes("ISO-8859-1〃),"gb2312〃)); System.out.println(new String(testString.getBytes("UTF8〃),"gb2312〃)); System.out.println(new String(testString.getBytes("GB2312〃),"gb2312〃)); System.out.println(new String(testString.getBytes("GBK"),"gb2312〃)); System.out.println(new String(testString.getBytes("BIG5〃),"gb2312〃)); 等等,上述代码的意思是用制定的编码格式去读取testString这个"乱码",并转换成gb2312(此处仅

网页中文乱码完美解决方案

网页中文乱码 既然后面charset设置为gb2312,那么你打开这个网页,然后另存,保存的时候记得把编码改成gb2312,不然的话charset就会误导浏览器,这样就会乱码了。 2.php编网页出现乱码,我把编码改成utf-8 前台显示正常了,但是有东西输入到数据库再提取出来还是不正常 3.apache+php+mysql 为何会出现乱码 我们在做PHP项目的时候,经常会遇到中文乱码的问题,有时候编码问题还导致MYSQL的报错。中文乱码总共有三个原因 1:APACHE服务器设置导致乱码 2:PHP,或者HTML页面编码导致中文乱码 3:MYSQL数据库的表以及字段编码导致中文乱码 我们分别从这三个部分来探究PHP程序设计中的编码问题 在这之前我们要了解一些基本理论: 1、文件编码 每个文件在保存的时候都可以选择以什么编码保存,例如用WINDOWS的记事本创建一个文件可以选择ANSI 以及UTF8等等编码。我们选择了什么编码该文件就以这种编码方式保存在硬盘上。读取该文件数据的时候也会指定一种编码来打开,如果指定的编码与文件保存的时候的编码不一样的话就会出现乱码 2、HTML的编码 在网页头部一般有这样一个 区域 这个的意思是让客户端知道,接下来输出的是html代码(text/html),并且以下输出的内容都将是utf-8编码的。如果我们用记事本创建一个HTML文件该文件包含 但是在保存的时候却以ANSI编码格式保存,那么我们用浏览器打开这个文件时,浏览器看见META 行的UTF8编码设置后就将文件以UTF8格式输出,而文件本来是ANSI编码,这样便出现了中文乱码。 一:APACHE服务器编码 在APACHE配置文件中有一行是编码的设置默认的是AddDefaultCharset ISO-8859-1,大部分人认为应该将这句改为AddDefaultCharset UTF-8 。而蜗牛认为这是误人子弟。这项配置是告诉APACHE服务器选用什么样的编码来输出WEB页面(这样做会忽略,HTML页面中的页面编码的设置EG:),如果我们建立一个GB2312的页面就会出现中文乱码。所以最好的方法是将AddDefaultCharset ISO-8859-1这一项注释掉#AddDefaultCharset 二:PHP编码问题 php最终生成的是文本文件,而他要从数据库中取出文本数据,还要把文本数据写到数据库中。由于MYSQL并不知道PHP发送给他的是什么编码的数据,所以需要客户端PHP告诉他存取的是什么编码的数据。然后MYSQL会自动将PHP传送来的数据转换成目标编码格式的

Flash中出现中文乱码的解决办法

Flash中出现中文乱码的解决办法 在编辑flash文件中加载了非Unicode 编码的外部txt文本文件时,有些中文就不能正常显示。 解决办法: 用鼠标右键单击舞台上的元件,从弹出的快捷菜单中选择“动作”选项,打开动作脚本编辑面板,键入下面脚本https://www.doczj.com/doc/a09578162.html,eCodepage = true;脚本解释:显示中文字符的语句,使外部文本文件中的中文字符能正常显示。否则只能显示英文字符,中文字符为乱码。例子:on (release) {loadVariablesNum("chem.txt", 0);https://www.doczj.com/doc/a09578162.html,eCodepage = true;} 说明: 对于作为外部文件包含或加载的文本(使用#include 命令,loadVariables() 或getURL 动作,或LoadVars 或XML 对象),保存这些文本文件时必须使用Unicode 对其进行编码,这样Flash Player 才能将其识别为Unicode。若要使用Unicode 对外部文件进行编码,请在支持Unicode 的应用程序(例如,Windows 2000 上的“记事本”)中保存这些文件。 如果包含或加载了非Unicode 编码的外部文本文件,则应将https://www.doczj.com/doc/a09578162.html,eCodepage 设置为true。在加载数据的SWF 文件的第一帧中,在最前面添加以下代码(第一行代码): https://www.doczj.com/doc/a09578162.html,eCodepage = true; 如果有这一行代码,Flash Player 将使用运行Flash Player 的操作系统

的传统代码页来解释外部文本。对于英文Windows 操作系统,该代码页通常为CP1252;对于日文操作系统,该代码页通常为Shift-JIS。如果将https://www.doczj.com/doc/a09578162.html,eCodepage 设置为true,Flash Player 6 和更高版本处理文本的方式与Flash Player 5 相同。(Flash Player 5 在处理文本时,将所有文本都视为按运行播放器的操作系统的传统代码页编码的文本。) 如果将https://www.doczj.com/doc/a09578162.html,eCodepage 设置为true,应注意您的外部文本文件中使用的字符必须包含在运行播放器的操作系统的传统代码页中,这样才能显示该文本。例如,如果您加载了一个包含中文字符的外部文本文件,这些字符在使用CP1252 代码页的系统上将无法显示,因为该代码页不包含中文字符。 若要确保所有平台上的用户都能查看您的SWF 文件中使用的外部文本文件,应使用Unicode 对所有外部文本文件进行编码,并将https://www.doczj.com/doc/a09578162.html,eCodepage 设置保留为其默认设置false。这样,Flash Player 6 和更高版本将按Unicode 解释文本。

乱码的原因及处理方法

乱码的原因及处理方法 2012-05-09 17:16 困扰已久的乱码问题终于得到解决,希望下次出现更多问题,解决问题的过程很愉快! 关于jsp乱码问题的解决 2009-01-22 21:32 关于jsp乱码问题的解决。 1 最基本的乱码问题。 这个乱码问题是最简单的乱码问题。一般新会出现。就是页面编码不一致导致的乱码。 <%@ page language="java" pageEncoding="UTF-8"%> <%@ page contentType="text/html;charset=gb2312"%> 中文问题 我是个好人 三个地方的编码。 第一个地方的编码格式为jsp文件的存储格式。Eclipse会根据这个编码格式保存文件。并编译jsp文件,包括里面的汉字。 第二处编码为解码格式。因为存为UTF-8的文件被解码为iso8859-1,这样 如有中文肯定出乱码。也就是必须一致。而第二处所在的这一行,可以没有。

缺省也是使用iso8859-1的编码格式。所以如果没有这一行的话,“我是个好人”也会出现乱码。必须一致才可以。 第三处编码为控制浏览器的解码方式。如果前面的解码都一致并且无误的话,这个编码格式没有关系。有的网页出现乱码,就是因为浏览器不能确定使用哪种编码格式。因为页面有时候会嵌入页面,导致浏览器混淆了编码格式。出现了乱码。 2 表单使用Post方式提交后接收到的乱码问题 这个问题也是一个常见的问题。这个乱码也是tomcat的内部编码格式 iso8859-1在捣乱,也就是说post提交时,如果没有设置提交的编码格式,则会以iso8859-1方式进行提交,接受的jsp却以utf-8的方式接受。导致乱码。既然这样的原因,下面有几种解决方式,并比较。 A 接受参数时进行编码转换 String str = new String(request.getParameter("something").getBytes("ISO-8859-1"),"utf-8");这样的话,每一个参数都必须这样进行转码。很麻烦。但确实可以拿到汉字。 B 在请求页面上开始处,执行请求的编码代码 request.setCharacterEncoding("UTF-8"),把提交内容的字符集设为UTF-8。这样的话,接受此参数的页面就不必在转码了。直接使用String str = request.getParamete("something");即可得到汉字参数。但每页都需要执行这句话。这个方法也就对post提交的有效果,对于get提交和上传文件时的enctype="multipart/form-data"是无效的。稍后下面单独对这个两个的乱码情况再进行说明。 C 为了避免每页都要写request.setCharacterEncoding("UTF-8"),建议使用过滤器对所有jsp进行编码处理。这个网上有很多例子。请大家自己查阅。 3 表单get提交方式的乱码处理方式。 如果使用get方式提交中文,接受参数的页面也会出现乱码,这个乱码的原因也是tomcat的内部编码格式iso8859-1导致。Tomcat会以get的缺省编码方式iso8859-1对汉字进行编码,编码后追加到url,导致接受页面得到的参数为乱码/、。 解决办法: A 使用上例中的第一种方式,对接受到的字符进行解码,再转码。 B Get走的是url提交,而在进入url之前已经进行了iso8859-1的编码处

jsp页面显示中文乱码解决

jsp页面显示中文乱码: jsp页面的编码方式有两个地方需要设置: <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <%@ page contentType="text/html;charset=utf-8"%> 其中:pageEncoding 指的是jsp文件本身在本地保存时的编码方式。contentType的charset 是指服务器发送网页内容给客户端时所使用的编码。 从第一次访问一个jsp页面开始,到这个页面被发送到客户端,这个Jsp页面要经过三次编码转换: 第一阶段是jsp编译成.java,它会根据pageEncoding的设定读取jsp,结果是由指定的编码方案翻译成统一的UTF-8 JAVA源码(即.java),如果pageEncoding设定错了,或没有设定,出来的就是中文乱码。 第二阶段是由JAVAC的JAVA源码至java byteCode的编译,不论JSP编写时候用的是什么编码方案,经过这个阶段的结果全部是UTF-8的encoding的java源码。 JAVAC用UTF-8的encoding读取java源码,编译成UTF-8 encoding的二进制码(即.class),这是JVM对常数字串在二进制码(java encoding)内表达的规范。 第三阶段是Tomcat(或其的application container)载入和执行阶段二的来的JAVA二进制码,输出的结果,也就是在客户端见到的,这时隐藏在阶段一和阶段二的参数contentType就发挥了功效 所以最终的解决方法为: 在jsp页面设置pageEncoding或者contentType的其中一个为支持中文的编码格式(如utf-8,gbk,gb2312)。因为设置一个的话,另一个默认会和它一样。 如果两个都设置的话,必须保证两个都是支持中文编码(不一定要一样)。 最佳建议设置如下: <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <%@ page contentType="text/html;charset=utf-8"%>

PHP中文乱码解决方法

PHP中文乱码解决方法 一.首先是PHP网页的编码 1.php文件本身的编码与网页的编码应匹配 a.如果欲使用gb2312编码,那么php要输出头:header(“Content-Type:text/html; charset=gb2312"),静态页面添加,所有文件的编码格式为ANSI,可用记事本打开,另存为选择编码为ANSI,覆盖源文件。 b.如果欲使用utf-8编码,那么php要输出头:header(“Content-Type:text/html; charset=utf-8"),静态页面添加,所有文件的编码格式为utf-8。保存为utf-8可能会有点麻烦,一般utf-8文件开头会有BOM,如果使用session就会出问题,可用editplus来保存,在editplus中,工具->参数选择->文件->UTF-8签名,选择总是删除,再保存就可以去掉BOM信息了。 2.php本身不是Unicode的,所有substr之类的函数得改成mb_substr(需要装mbstring 扩展);或者用iconv转码。 二.PHP与Mysql的数据交互 PHP与数据库的编码应一致 1.修改mysql配置文件my.ini或https://www.doczj.com/doc/a09578162.html,f,mysql最好用utf8编码 [mysql] default-character-set=utf8 [mysqld] default-character-set=utf8 default-storage-engine=MyISAM 在[mysqld]下加入: default-collation=utf8_bin init_connect='SET NAMES utf8' 2.在需要做数据库操作的php程序前加mysql_query("set names'编码'");,编码和php编码一致,如果php编码是gb2312那mysql编码就是gb2312,如果是utf-8那mysql编码就是utf8,这样插入或检索数据时就不会出现乱码了。

相关主题
文本预览
相关文档 最新文档