数据库乱码怎么解决,第1张

展开快讯

登录

首页

专栏

问答

沙龙

快讯

团队主页

开发者手册

智能钛AI

在线学习中心

TVP

返回腾讯云官网

彻底解决MySQL中文乱码

mysql是我们项目中非常常用的数据型数据库。但是因为我们需要在数据库保存中文字符,所以经常遇到数据库乱码情况。下面就来介绍一下如何彻底解决数据库中文乱码情况。

1、中文乱码

11、中文乱码

无法插入中文字符:

12、查看表字符编码

我们可以看到表的默认字符集是latin1

所以我们在创建表的时候就需要指定表的字符集:

这样在Linux里面可以访问并且可以插入与访问这个表了。

13、数据库与操作系统编码

虽然在服务器端可以显示中文正常,但是在客户端可能会显示乱码。因为我们的服务器是UTF8。

而且数据库的编码也存在问题。

这里我们可以看character_sert_database与character_set_server的字符集都是latin1那么在mysql数据库中,server,database,table的字符集都默认是latin1下面我们就来看看如何解决mysql乱码情况。

2、mysql设置变量的范围

21、session范围

查看数据库编码:

修改字符编码:

我们可以看到字符集已经修改成都是utf8了。但是这里有一个问题,那就是我们重新打开一个命令窗口然后查看数据编码就会出现下面的画面:

你好!

你好朋友,这样的情况你可以使用360系统急救箱来处理。具体步骤如下:

1、双击360系统急救箱,然后单击“开始系统急救”。

2、系统引擎初始化完成后,单击“修复”,勾选需要修复的类型,然后单击“立即修复”,完成后重新启动电脑。如果你不知道属于哪一类故障不懂得应该修复哪一类可以使用系统推荐的修复级别,不用选择而直接单击“立即修复”,或者勾选“全选”然后直接单击“立即修复”。

希望我的回答对你有帮助。

解决电脑乱码问题

当我们浏览网页、打开文件或邮件,运行软件时,经常会看到乱码,通常是由于源文件编码,视窗系统不能正确识别造成的的,也可能是其他原因。乱码给我们带来了太多的烦恼,为了帮助大家完全摆脱乱码,下面我们就来探讨一下乱码的形成原因及其消除方法。

  一、乱码有五种类型

  常见的乱码,一般能分成五种类型:

第一类是文本/文件文件乱码,这一般是由于源文件编码,和视窗系统使用的编码不通用造成的;

第二类是网页乱码,形成原因和第一类乱码类似;

第三类是视窗系统系统界面乱码,即中文视窗系统的菜单、桌面、提示框等显示乱码,主要是视窗系统注册表中有关字体的部分设置不当引起的;

第四类是应用程式的界面乱码,即各种应用程式(包括游戏)本来显示中文的地方出现乱码,形成原因比较复杂,有第二类的乱码原因,也可能是软件用到的中文链接库,被英文链接库覆盖造成的;

第五类是邮件乱码,形成原因也极其复杂。

  

  二、怎么消除文本/文件文件乱码

  形成原因:一般是由于文件采用的字符集,系统不支持造成的。例如繁体中文的文件显示在简体中文系统下,或相反的情况,就会造成文件显示时乱码。只要你内码转换正确,例如把原本是繁体的内码,转换为简体内码(或相反),即可消除乱码。

  解决办法:有以下四种解决办法:

  1、使用Word2003/XP转换内码

  Word2003/XP支持众多的语言,能正确显示非Unicode类型的文本文件,单击“工具”菜单下的“语言”/设置语言,你能把默认语言设置成非中文,例如日语,这样Word就能正确显示日文了。

  当然你也能用他进行简体中文和繁体中文之间的转换工作,如果文件有乱码,你转换一下即可消除。例如要把繁体中文转换为简体中文,方法是:选择要转换内码的文件,在弹出的对话框中,选择“其他编码”中的“繁体中文(BIG5)”一项,打开此文件时就不会出现乱码。

  

  在Word2003/XP中,当保存时选择“文件”中的“另存为”,先存为“WORD”文件,存盘后打开再存为纯文本等其他格式;或在菜单栏中选择“工具/语言/中文简繁转换”,内码转换以后再保存。

  3、使用内码转换工具

  除此之外,使用内码转换工具也能消除此类乱码,你只要对BIG5(繁体中文)和GB2312(国标码、简体中文)进行相互转换即可实现。常用的内码转换工具有:

   4、使用WPS2000转换内码

  WPS2000也能转换内码,支持GB2312、BIG5、GBK等三种主要的汉字编码,并可在输出RTF、TXT、HTM格式文件时对内码进行转换。

  三、怎么消除网页乱码?

  形成原因:网页乱码是浏览器(IE等)对HTML网页解释时形成的,如果网页制作时编码为A,浏览器却以编码B显示该网页,就会出现乱码,因此只要你在浏览器中也以编码A显示该网页,就会消除乱码。

  例如网页的代码中有形如:〈HTML〉〈HEAD〉〈META CONTENT=“text/html;charset=ISO-8859-1”〉〈/HEAD〉的语句,浏览器在显示此页时,就会出现乱码,因为浏览器会将此页语种辨认为“欧洲语系”。

  解决办法:有以下四种解决办法:

  1、在浏览器中选择“编码”菜单

  事先为浏览器安装多语言支持包(例如在安装IE时要安装多语言支持包),这样当浏览网页出现乱码时,即可手工更改此类网页的编码方式,在浏览器中选择菜单栏下的“查看”/“编码”/“自动选择”/简体中文(GB2312),如为繁体中文则选择“查看”/“编码”/“自动选择”/繁体中文(BIG5),其他语言依此类推,选择相应的语系,这样便可消除网页乱码现象。

  2、修改网页代码

  用FrontPage等软件打开出现乱码的网页,修改该网页代码,在以下句子中

  〈META CONTENT=“text/html;charset=ISO-8859-1”〉,将语种“ISO-8859-1”改为GB2312,如果是繁体网页则改为BIG5。

  3、无乱码保存网页

  用浏览器打开该网页,在“查看”/“编码”中选择“自动选择”,存盘时保存类型选“WEB页”,编码选择“UNICODE”,这样保存过的网页再次打开时,在浏览器菜单“查看”/“编码”中不管选择简体中文(GB2312)、简体中文(HZ)还是UNICODE(UTF-8)或繁体中文(BIG5),最终显示都不会出现乱码。

  4、使用多内码显示软件

  使用多内码显示软件来转换内码,也能消除乱码。常用多内码显示软件有:

  四、怎么消除视窗系统系统界面乱码?

  形成原因:这类乱码是由于视窗系统注册表中关于字体部分设置不正常造成的,即使你用内码翻译软件(如南极星、MagicWin98等)处理也不会消除。

  解决办法:在视窗系统注册表中,恢复关于字体部分的正确设置。

  1、利用显示正常的计算机

  如果有一台视窗系统版本相同、显示正常的计算机能利用,你能如下步骤进行恢复:在正常机器上选择“开始”/“运行”,在对话框中键入“REGEDIT”,打开注册表编辑器;光标定位到“HKEY_LOCAL_MACHINE\SYSTEM\CURRENT CONTROL SET\CONTROL\FONTASSOC”,选择“注册表/导出注册表文件”,选择“分支”,导出该分支注册表信息到文件(如LIREG)中(如下图);把LIREG文件COPY到显示乱码的机器上,在显示乱码机器上运行REGEDIT,选择“注册注册表”/“导入注册注册表”,把LIREG文件导入注册表中。

  

  2、在显示乱码的计算机上操作

  如果没有显示正常的计算机能利用,就需要你手工恢复字体部分注册表项,方法有以下两种:

  第一种方法:用记事本编辑一个文件,然后保存为扩展名“REG”(文件名随意),再用鼠标右键单击这个文件,在右键菜单中选择合并,即可完成对注册表的改动。该文本文件的内容如下:

   REGEDIT4

   [HKEY_LOCAL_MACHINE\System\CurtentControlset\control\fontassoc]

   [HKEY_LOCAL_MACHINE\System\CurtentControlset\control\fontassoc\Associated DefaultFonts]

   "assocSystemFont"="simsunttf"

   "FontPackageDontCare"="宋体"

   "FontPackageRoman"="宋体"

   "FontPackageSwiss"="宋体"

   "FontPackageModem"="宋体"

   "FontPackageScript"="宋体"

   "FontPackageDecorative"="宋体"

   [HKEY_LOCAL_MACHINE\System\CurtentControlset\control\fontassoc\Associated CharSet]

   "ANSI(00)"="yes"

   "SYMBOL(02)"="no"

   "OEM(FF)"="yes"

   "GB2312(86)"="yes"  

  第二种方法:在出现乱码的计算机上,单击菜单“开始”/运行,键入REGEDIT打开注册表;找到“HKEY_LOCAL_MACHINE\SYSTEM\CURRENT CONTROL SET\CONTROL\FONTASSOC”,正常情况下会有ASSOCIATED DEFAULTFONTS、ASSOCIATED CHARSET两个目录,这些目录中正确的参数如下表所示:

  

  当出现汉字乱码时,上述两个目录中内容就会不完整,有的没有ASSOCIATED CHARSET目录、或其中内容残缺不全;有的ASSOCIATED DEFAULTFONTS下内容残缺。只要你打开注册表,在“HKEY_LOCAL_MACHINE\SYSTEM\CURRENTCONTROLSET\CONTROL\FONTASSOC”下,根据以上正确内容恢复即可。五、怎么消除应用程式的界面乱码?

  目前有些软件发行了Unicode版本,这是一种通用的字符编码标准,涵盖了全球多种语言及古文和专业符号,这种版本的软件运行在所有系统和语言上都不会乱码,如果是非Unicode编码的程式,就会有乱码现象。

  形成原因:原因有三种。如果是由于视窗系统注册表中关于字体设置的信息不正确造成的,你能用下面“怎么消除视窗系统系统界面乱码”介绍的办法去解决;如果用上法解决不了,那就可能是由于软件的中文链接库,被英文链接库覆盖而引起的。这种现象经常发生在用微软研发工具例如VB、VC研发的中文软件上,这类软件中,菜单等显示界面上的汉字都是受一个动态链接库(DLL文件)控制,而软件的这个动态链接库一般安装在视窗系统\System目录下,如果以后安装了某个英文软件也使用同名的动态链接库,则英文软件的动态链接库就会覆盖中文链接库,这样,运行中文软件时就会调用英文的动态链接库,因此出现乱码。解决办法:重新安装中文软件,恢复中文动态链接库即可。

  如果以上方法也无济于事,对于Win9X/ME系统,你能安装使用MagicWin98(下载地址http://wwwskycncom/soft/3047html)、南极星等内码转换软件,转换内码后即可消除乱码;对于WinXP系统,建议使用微软多语言支持工具MicrosoftAppLocale(下载地址http://wwwskycncom/soft/12582html),利用他为指定程式设置相应的语言区域,这样也可消除乱码。

  六、怎么消除邮件乱码?

  邮件乱码的形成原因非常多,主要有以下几个方面,针对以下几种形成原因,应该采取不同的乱码消除方法:

  1、收发信双方的语种不同导致的

  收发双方使用的操作系统的不同,能造成乱码。比如发件人使用的是日文的视窗系统,而收件人使用的是简体中文的视窗系统,这样的邮件当然会造成乱码。对于中文电子邮件,如果收信方所用的操作系统是英文环境、而且没有外挂中文系统或未转换为中文(如南极星等)编码方式,也会无法看到中文、只可见乱码。所有的双字节字符(如中文简/繁体的GB和BIG5码及日文的JIS、EUC和朝鲜文的 KSC码等)在非本语种操作系统下都会出现乱码;同样在中文简体的GB码环境下,看其他双字节字符时也只能看到乱码。

  解决办法:安装多语言支持包或使用多内码显示平台(如南极星等),对收到的邮件,根据其使用的语种转换到相应的编码方式即可消除乱码。

  2、发信服务器不支持8位(非ASCII码格式)传输

  邮件传输机制或邮件编码的不同,可能造成邮件服务器不支持8位(非ASCII码格式)传输而形成邮件乱码。例如直接发送中文或二进制等非ASCII码格式的邮件(如中文双字节文件、文件jpg、可执行文件exe或压缩文件zip等二进制文件)时,邮件服务器有可能无法处理,便把信件中每个字符的第八位都过滤掉,从而造成邮件信息的失真或损坏,在收到邮件时就是一堆乱码。

  解决办法:只能由发件人解决。当发送8位格式的文本文件时,必须事先进行编码,将文件转换为7位ASCII码或更少位数的格式,然后才能确保文件的正确传送。收件人收到7位或更少位格式的邮件后,能再转换为8位的格式,这样就可避免乱码。

  3、收发端用的EMAIL软件和设置不同

  一般EMAIL软件的"附件"功能都能自动对信件先进行编码,然后送出。这样只要收信人使用的EMAIL软件(如Outlook XP等)能差别信件的编码方式,即可自动将信件解码。如果收发件人所用的EMAIL软件默认设置不同、收发件人自己制定的一些选项不同,在收到编码的信件后,系统就未必能识别出信件所用的编码方法,自然也无法自动解码,这样就会出现乱码。

  解决办法:如果你用OE收中文邮件,看到的是一篇乱码,能查一下“查看”-“编码”下,是否选了“简体中文(GB2312)”,选对了就不会有问题。

  此外,你也能用Winzip+IE来解码,方法是:把乱码邮件的内容,拷贝到剪贴板中,然后将其粘贴到记事本中,存为文本文件(例如LItxt),再将其后缀改为uue(改为LIuue),点击此文件,会启动Winzip,然后启动IE,把Winzip中的001txt文件拖到IE窗口中,就会显示邮件原来的内容,而不会看到乱码。  

  4、Email软件不能识别邮件的编码方法

  邮件的编码方式主要有:Uuencode、Base64 encode、QP-encode、BINHEX等。如果Email软件不能识别邮件的编码方法,就会显示邮件时出现乱码。因此,你能根据邮件中的关键字符判断编码方法,选取合适的解码软件进行解码。

  (1)、QpencodeQP编码

  该编码全称“Quoted-Printable Content-Transfer-Encoding”,因为这种格式邮件的内容都是ASCII字符集中能打印的字符,所以名称中含有printable。大体格式为:  =A1A=B1z=A6n=A1I=A7=DA=A6b=BA=F4=B8=F4=A4W=B1o=E5==ABH=A5=F3=B0=DD=C3D=B1M=Aea=A1A

  特征:内容通常有非常多等号"=",因此不必看"信头"也能判断是否为QP编码。

  解码办法:把邮件中类似A1A=B1z=A6n…的部分编码全部复制下来,贴到一个新的纯文本文件中,然后在文件头部加入Quoted-pintable格式的文件头:

  Contenet-Type:text/plain;Charset=”GB2312”

  Content-Transfer-Encoding;Quoted-pintable

  然后以“EML”为后缀保存文件,用资源管理器双击打开文件即可显示正确的内容。如果更有部分汉字乱码,能用WINZIP对存盘后的EML文件进行解压,即可看到正确的内容。

  (2)MIME/BASE64 encode编码

  该编码方式将3个字节(8位)用4个字节(6位)表示,由于编码后的内容是6位的,因此可避免第8位被截掉,大体格式为:

    MIME-Version:10

    Content-Type:text/plain; charset="us-ascii"

    Content-Transfer-Encoding:base64

  Status:R SGmhQbF6pm6hSafapmK69Lj0pFexb6q+sXqsT6Skp OWrSKXzs

  N3DRLFNrmGhQQ0Kq1+sTqq6vdCx

0LF6tFit07Ddw0ShRw0KDQqtuqX9p2m2RL

  F6p9qoz6XOIE1Py3Jvc29mdCuiBJbnRlcm5ldCBN。

  特征:乱码前一般有如下几部分"信头":Content-Type(内容类型)、charset(字符集)及Content-Transfer-Encoding(内容传输乱码方式)。

  解码办法:用EMAIL软件,选择编码中BASE64 选项就可解码,解码后会消除乱码。

  (3)、BINHEX编码

  这种编码方式大体格式为:

  (This file must be converted with Binhex40)SGmhQbF6pm6hSafapmK69Lj0pFexb6qss

  Tqq6vdCx

0LF6tFit07Ddw0ShRw0KDQqtuqX9p2m2RLF6p9qoz6XOIE……

  解码办法:用EMAIL软件对他解码;也可在EMAIL软件中保存乱码邮件,存为后缀为“HQX”格式的文件,然后用WINZIP解码展开。解码后会消除乱码。

  (4)、UTIF-7/UTIF-8编码

  他们是UNICODE的两种转换码。

  

  (5)、Uuencode编码

  这是UNIX环境下使用的编码方式,目前已非常少用,大体格式为:

    begin 644 kkzip M1G)O;2!I;&EN+F)B3T!C(VEE+FYC=’4N961U+G1W(%=E9"!;W8@(#8@,3(ZM,SDZ,C4@,3DY-@I296-E:79E9#H@9G)O;2!F;&%B;6%I;"YF;&%B+F9U:FET。

     end

  特征:乱码前面含有"begin xxx",后面是编码前的原始文件名(如kkzip);接着是已过编码的信件内容(如上述的乱码部分);最后一行为"end"

  解码办法:可用BECKY!EUDORA等EMAIL软件,选择编码中相应的选项就可解码;也能在EMAIL软件中保存乱码邮件,存为后缀为“UUE”格式的文件,然后用WINZIP解码展开,解码后就会消除乱码。

 七、发信方怎么避免产生乱码邮件?

  为了避免别人收到乱码,发信方应该采取以下的措施:

  1、设定默认自动为7位编码

  在邮件客户端软件中的书写(撰写)选项中,设定默认自动为7位编码。因为当你发送 8位格式的文本文件时,必须事先进行编码,将文件转换为7位ASCII码或更少位数的格式,然后才能确保文件的正确传送。收件人收到7位或更少位格式的邮件之后,能再转换为8位的格式,这样就能阅读了。

  2、发送前在签字栏中注明使用的汉字编码

  发送中文邮件前,最佳在固定的签字栏中注明自己所使用的汉字码标准(例如GB2312、中文HZ、GBK等);港澳台及东南亚地区邮件作者在使用BIG5 码撰写完邮件、向内地发送前,要转换成上述三种简体国标码中的一种形式、并在签字栏中注明。如不转换则可能无法阅读,因为国内用户使用的邮件系统有非常多不支持BIG5码。

  3、正确设置EMAIL软件

  选择优秀的Email收发软件能有效地解决邮件乱码。如果使用Outlook 2003/XP,应在软件中把“简体中文(GB2312)作为默认的邮件使用语言,选择“国际设置”/为接收的所有邮件使用默认的编码。

  如果使用英文EMAIL软件,应设置成:文字设定DEFAULT CHARSET:ISO 8859-1(LATIN1);编码方式ENCODING:QUOTED-PRINTABLE,不可选择7位(因为7位不支持中文);字码页CODE PAGE(可选):936或HZ-GB-2312,以支持整字识别;邮件格式:MIME;字体:宋体

  如果使用其他中文EMAIL软件,应设置成:文字设定DEFAULT CHARSET:简体中文GB2312;编码方式ENCODING:QUOTED-PRINTABLE;邮件格式:MIME;字体:宋体

  4、发送重要信息时先发测试信

  发送重要信息时,为了确认是否无须编码即可发送正文,应该先发送测试信。而且还应确定收件人能否对附件文件进行解码。如果发送已编码的邮件,则最佳添加足够的“信头”信息,以便收件人知道所需的解码方法。建议对uuencode/UUDeview编码方式用uuencoding作信头,对mpack编码方式用base64 encoding作信头。

  如果发/收件人之间远隔万里,则传送过程中,第八位将可能被截掉。这时最佳先在正文中用中文给收件人发一封测试信,并了解对方能否正确收到邮件正文。如果第八位被截掉,则收件人将会看到一些乱码,而不是上述的uu/b64/Qp等格式,而且这种信件几乎不可恢复。

  对策:在Netscape、Eudora或Pegasus Mail等你所使用的邮件系统中,选择其最佳选择项或选项设置中的"Quoted Printalbe"或"MIME encoding

  5、尽量利用“附件”功能发送文件

  几乎所有的邮件软件,如Netscape、The Bat!、 Becky! 等邮件系统附加这类非标准 ASCII码格式的文件时,附加文件通常能自动进行“base64”方式编码(仅对附件部分进行编码)。在用"附件"方式发送邮件之前,无需进行编码;否则适得其反。因为邮件软件能够自动成功解码这类“附加”文件,因此在发送中文类邮件时应该最佳选择这种方法。

  如果无法以附件方式发送文件,则必须在正文中发送中文或二进制文件

  八、收信方怎么避免邮件显示乱码?

  收信方应该首先查找邮件的签字栏或正文中,有无指明对方使用的汉字编码类别;然后在Outlook XP“视图”菜单下选中“编码”,随后将出现全部的汉字编码,在其中选择邮件所指明的一种。

  如果收到的邮件中没有指明所用的汉字编码,则能顺序单击选择编码,直到邮件正文显示正确为止。如果你使用的是Netscape,则可在 Option菜单下的Document Encode中选择相应的项目。

  九、在跨语种操作系统间收发电子邮件,怎么确保不会乱码?

  如果对方使用非中文系统,你给他发中文邮件时,他打开你发的中文邮件,就会出现乱码。解决办法有两种:

  1、用绘图软件书写中文邮件

  用画笔等绘图软件书写中文邮件,然后把中文邮件以GIF图像格式保存,最后压缩之、作为邮件附件发送。

  运行绘图软件,在中输入文字,用GIF格式保存,将属性置为黑白模式(以减少体积),然后用WINZIP把他压缩成ZIP格式,作为附件在邮件中发送,这样不管对方在何语言平台下,都不会出现乱码,收信人不必去下载PDF文件阅读器,阅读起来也非常方便。

  2、使用专门的工具转换和阅读

  EMAIL AID之类的工具能把中文邮件转换为AID格式文件,你把该格式文件发给对方,他再用EMAIL AID打开观看即可。

  EMAIL AID(UCWIN GOLD 10附带的)能把文本文件转换为AID格式文件,大小只比原TXT文件增加几K。写好中文邮件后,用文本格式存盘,然后你运行EMAIL AID,以AID格式保存,最后你把AID文件连同EMAIL AID软件一起作为附件插在信中。对方收到信后,只需运行EMAIL AID,打开AID格式文件即可看到汉字,不管对方在何种语言平台下,都不会出现乱码。 

使用Filezilla client FTP客户端登陆某些FTP站点会出现中文乱码,原因是FTP服务器端编码与filezilla client端编码不一致造成的,解决方法如下:

文件-站点管理-选中要登陆的站点-字符集-选择”强制UTF-8″ 或使用自定义字符集GB2312,二者之一定能解决中文显示乱码的问题。

问题一:网页出现乱码怎么办 网页出现乱码怎么办

解决办法:有以下四种解决办法:

1、在浏览器中选择“编码”菜单

事先为浏览器安装多语言支持包(例如在安装IE币安装多语言支持包),这样当浏览网页出现乱码时,即可手工更改此类网页的编码方式,在浏览器中选择菜单栏下的“查看“编码”/“自动选择”/

简体中文(GB2312),如为繁体中文则选择“查看”/“编码”/“自动选择”/繁体中文(BIG5),其他语言依此类推,选择相应的语系,这样便可消除网页乱码现象

2、修改网页代码

用FrontPage等软件打开出现乱码的网页,修改该网页代码,在以下句子中 〈META CONTENT=“text/html;charset=ISO-8859-1”〉,将语种“ISO-8859-1”改为GB2312,如果是繁体网页则改为BIG5

3、无乱码保存网页

用浏览器打开该网页,在“查看”/“编码”中选择“自动选择”,存盘时保存类型选“WEB页”,编码选择“UNICODE”,这样保存过的网页再次打开时,在浏览器菜单“查看”/“编码”中不管选择简体中文(GB2312)、简体中文(HZ)还是UNICODE(UTF-8)或繁体中文(BIG5),最终显示都不会出现乱码

问题二:如何解决HTML网页中文显示乱码的方法 把文件保存成utf-8的编码,仿着上面的位置,在页面加上中间那行代码

问题三:浏览器浏览个网页全是乱码怎么回事 应该是网页问题。看看其他的网页有事情吗。如果没有问题。把页面关了重新打开。或者换成qq浏览器试试。他打开网页的速度较快。 里面的手机软件和游戏很齐全,各种类型的都可以在这里面找到,所以还是很方便的哦。

问题四:页面乱码问题怎么解决? 1第一个地方的编码格式为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(requestgetParameter(something)getBytes(ISO-8859-1),utf-

8) ; 这样的话,每一个参数都必须这样进行转码。很麻烦。但确实可以拿到汉字。

B,在请求页面上开始处,执行请求的编码代码, requestsetCharacterEncoding(UTF-8),把提交内容的字符集设为UTF-8。这样的话,接受此参数的页面就不必在转码了。直接使用  String str = requestgetParameter(something);即可得到汉字参数。但每页都需要执行这句话。这个方法也就对post提交的有效果,对于get提交和上传文件时enctype=multipart/form-data是无效的。稍后下面单独对这个两个的乱码情况再进行说明。

C,为了避免每页都要写requestsetCharacterEncoding(UTF-8),建议使用过滤器对所有jsp。

现在将常见的乱码问题分为JSP页面显示中文乱码、表单提交乱码两类。

1)JSP页面中显示中文乱码

在JSP文件中使用page命令指定响应结果的MIME类型,如

2)表单提交乱码

表单提交时(post和Get方法),使用requestgetParameter方法得到乱码,这是因为tomcat处理提交

的参数时默认的是iso-8859-1,表单提交get和post处理乱码问题不同,

下面分别说明。

(1)POST处理

对post提交的表单通过编写一个过滤器的方法来解决,过滤器在用户提交的数据被处理之前被调用

,可以在这里改变参数的编码方式,过滤器的代码如下:

Java代码

CharacterEncodingFilterjava:

public class CharacterEncod>>

问题五:网站出现乱码,怎么解决 〈HTML〉〈HEAD〉〈META CONTENT=“text/html;charset=ISO-8859-1”〉〈/HEAD〉〈/HTML〉的语句,浏览器在显示此页时,就会出现乱码。因为浏览器会将此页语种辨认为“欧洲语系”。

解决办法:

1将语种“ISO-8859-1”改为GB2312,如果是繁体网页则改为BIG5。

2不修改网页代码,事先为浏览器安装多语言支持包(例如在安装IE时要安装多语言支持包),这样在浏览网页出现乱码时,就可以在浏览器中选择菜单栏下的 “查看”→ “编码”→“自动选择””→“简体中文(GB2312),如为繁体中文,则选择“查看”→“编码”→“自动选择””→“ 繁体中文(BIG5),其他语言依此类推选择相应的语系,这样可消除网页乱码现象。

3利用多内码显示平台来转换内码。

4网页无乱码保存的方法是:用浏览器打开网页时,在 “查看”→“编码”中选择“自动选择”,存盘时保存类型选 “Web页”,编码选择“UNICOD”,这样保存过的网页再次打开时,在浏览器菜单“查看”→“编码”中不管选择简体中文(GB2312)、简体中文 (HZ)还是UNICODE(UTF-8)或繁体中文(BIG5),最终显示都不会出现乱码。

5如果是数据库里取出的资料乱码,则请将数据库里所有表及字段的编码都设为与页面的一样

问题六:网页显示的是乱码怎么办 是打开别人的网页吗?如果是打开网页出现乱码的情况,是因为编码不统一的问题,解决办法,直接在乱码页面,右键--编码--如果是utf-8的话,你改成gb2312,如果是gb2312的话,你改成utf-8。就可以解决了。如果不是这两个的话,你直接改成这两个的任一试试。

如果是你自己做的网页的话,可以在网页最上边的meta的地方加上编码即可。

问题七:制作网页时乱码了,怎么办? 乱码分三种情况:

1乱码。

2javascript乱码

3数据库乱码(我用的是mysql,其他也一样,操作数据库是直接用phpmyadmin操作)

网页设计基本就这三种情况。笔者不幸的全遇到了(这是巧合吗?坑啊),但幸运的是,在笔者阅读了大量相关资料以及对乱码原理深入理解后,已经将其全部解决。

html乱码的解决

1你没有Dreamweaver的话:

把这行代码复制到你的之间,这会使你的网页打开时,浏览器默认编码为utf8,当然,建议你所有的网页编码统一,都设置为utf8,或者都设置为gb2312。

2如果你有Dreamweaver的话:

你可以不必记住这行代码,因为Dreamweaver可以设置,如图:

选择页面属性(上边的修改中也可以找到),选择标题/编码,更改编码确保编码统一(建议统一为utf8或gb2312)

选择统一编码后点击“应用”,Dreamweaver会自动将一行代码加入你的网页。

但是记住,要统一编码。在你制作第一张网页时就这样设置,这样做的好处是你以后用Dreamweaver编辑的每一张网页都会自动统一编码。

js乱码的解决

这里js乱码是指由js制作的弹窗内容为乱码的情况,这种情况很头疼,但一般不会出现,如果出现,不好解决。

1若你的js弹窗内容出现乱码,首先检查原网页代码中的输出内容是否是乱码(由于乱改页面设置,导致本来的汉字变成乱码)

2如果你确保你的原网页代码中不是乱码,那么说明js输出内容与页面编码不符,这时我们应强制将输出内容转变编码与页面编码统一。

强制转换编码的方法有很多,我这里使用php做到了这些

alert('$ss');;

>

这样做的好处是,无论网页编码是utf8还是gb2312,你的js弹窗内容都不会是乱码。但缺点也很明显,你的文件后缀名从需要改为php(否则php不被编译),而且php执行占用服务器内存,但只是转换编码并不用担心消耗太多服务器内存。

数据库乱码的解决

这里数据库乱码是指

1插入正常数据后,数据库里显示乱码

2正常数据读取出在页面显示乱码

3建立数据库时数据库(表、字段)的编码有问题

解决办法:

1插入数据库前将数据强行转换编码,与数据库统一。(这里笔者操作数据库所用的是php)

这样在数据库内查看数据时>>

问题八:打开网页老是乱码 怎么办 下载谷歌等浏览器测绩一下,如果好用,上你说的网站、或浏览其它网页时就用这个软件,这些都是不用IE做内核的,与你用IE不冲突(有问题请你追问我)。

其他在看看360浏览器试试,或还原系统或重装。

问题九:打开网页容易出现乱码是怎么回事 在页面的空白处右击鼠标,选择编码(E),再勾选自动选择。。刷新一下就好,希望能帮到你~~~

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 数据库乱码怎么解决

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情