建议题主好好debug调试一下
1,前台页面提交数据到后台接收,这个期间是否已经变成乱码。如果是,那就需要在前台进行编码转换,直至后台接收到的为正常的内容为止。
2,后台接收正常之后,期间有没有什么其他 *** 作(一般很少有变化),那就是在存储数据库的时候,对于数据库的编码有没有设定,如果没有设定的话,那就设定一下对应系统设置数据库编码的地方为 utf-8
其他的情况可能就得看真实环境进行分析
你的数据库 表 quan_weibo 中的content字段是什么类型? 需要选择nvarchar(max) 用来存储中文的,如果是英文是varchar(max),你可以先检查下这个。改变下数据库字段类型就可以了
C# 向数据库存的思路 , 将 读成二进制格式,存放在数据库的二进制格式的字段中。
如果需要取出,反过来 *** 作就可以了。
首先,这个问题一般都是字符集不匹配的问题;就是说数据库中存储数据用的字符集,和你连接数据库用的字符集不匹配。
然后,就是看你的数据库了
oracle的话
先确认数据库服务所采用的字符集,select userenv('language') from dual;
然后修改客户端的环境变量,比如set nls_lang=AMERICAN_AMERICAZHS16GBK
mysql的话,一般都是用utf8的字符集
在你客户端连接时,也要保证字符集一致才行
其它类型数据库的话,看具体的解决方案
汉字乱码现象有4种类型:
1文本乱码:是Windows系统显示乱码,如:菜单、桌面、提示框等。这是由于注册表中有关字体部分的设置不当引起的;
2文档乱码:是各种应用程序、游戏本来显示中文的地方出现乱码。这种乱码形成的原因比较复杂,有第1类的乱码原因,也可能是软件中用到的中文动态链接库被英文动态链接库覆盖所造成的;
3文件乱码:主要是指邮件乱码;
4网页乱码:是由于港台的繁体中文大五码(BIG5)与大陆简体中文(GB2312)不通用而造成的。
消除各类乱码的方法
一 系统乱码的消除方法
这类乱码是由于在Windows注册表中,关于字体部分配置不正常造成的,即使你用内码翻译软件处理也不会消除这类乱码。那怎么办呢?请跟我来:
方法一:找一台与你的Windows版本相同且显示正常的机器,依下列步骤进行:
1在正常机器上选择“开始”→“运行”,在对话框中键入“regedit”,打开注册表编辑器;
2请你将光标定位到“HKEY_LOCAL_MACHINE\ system\CurrentControlSet\Control\ Fontassoc”,然后选择“注册表”→“导出注册表文件”,再选择“分支”,导出该分支注册表信息到文件(如ZTREG)中;
3把ZTREG文件拷贝到你那显示乱码的机器上,方法是:在显示乱码的机器上运行“regedit”,打开注册表编辑器,选择“注册表”→“导入注册注册表”,把ZTREG文件导入注册表中即可。
方法二:如果你找不到一台与你的Windows版本相同且显示正常的机器,则需要手工恢复字体部分的注册表
项,其步骤是:
1首先在显示乱码的机器上选择“开始”→“运行”,在对话框中键入“regedit”,打开注册表编辑器;
2选择“HKEY_LOCAL_MACHINE\System\ CurrentControlSet\Control\Fontassoc”,正常情况下,会有Associated DeaultFonts、Associated CharSet两个文件夹,其正确的内容应是:
子目录内容
中文Win98
中文Win98(OEM版)
中文Win2000
Associated CharSet
ANSI(00)=“yes”
GB2312(86)=“yes”
DEN(FF)=“yes”
SYMBOL(02)=“no”
ANSI(00)=“yes”
GB2312(86)=“yes”
OEM(FF)=“yes”
SYMBOL(02)=“no”
ANSI(00)=“yes”
OEM(FF)=“yes”
SYMBOL(02)=“no”
Associated DefaultFonts
AssocSystemFont=“simsunttf”
FontPackageDecorative=“宋体”
FontPackageDontcare=“宋体”
FontPackageModern=“宋体”
FontPackageRoman=“宋体”
FontPackageScript=“宋体”
FontPackageSwiss=“宋体”
或
AssocSystemFont=“simsunttf”
FontPackage=“新宋体”
FontPackageDecorative=“新宋体”
FontPackageDontcare=“新宋体”
FontPackageModern=“新宋体”
FontPackageRoman=“新宋体”
FontPackageScript=“新宋体”
FontPackageSwiss=“新宋体”
3当出现汉字乱码时,上述两个文件夹中的内容就会不完整,有的没有Associated CharSet文件夹或其中的内容残缺不全;有的 Associated DefaulFonts下的内容残缺。如果遇到这种情况怎么办呢?其实你只要打开注册表编辑器,在 “HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Fonassoc”下,根据以上的正确内容恢复即可。
二 应用程序、游戏乱码的消除方法
明明是中文软件,可显示界面上却出现乱码,这可能是由于注册表中关于字体设置的信息不正确地被改变而造成的,一般是因为软件的中文链接库被英文链接库覆盖而引起的,这种现象经常发生在用微软开发工具,例如VB、VC开发的中文软件上。在这类软件中,菜单等显示界面上的汉字都是受一个动态链接库“DLL文件”控制,而软件的这个动态链接库一般是安装在Win 98/2000的System目录下的,如果以后你安装了某个英文软件也使用同名的动态链接库,则英文软件的动态链接库就会覆盖掉你原先的Windows\System下的中文软件的动态链接库。这样,当你运行中文软件时就会调用英文的动态链接库,因此出现乱码。解决办法是重新安装中文软件,恢复中文动态链接库即可。
把页面的编码方式 改成utf-8 或者 把页面传上来的数据处理一下
String str=new String(strgetBytes("iso8859-1"),"utf-8")
/// <summary>
/// 将Unicode编码转换为汉字字符串
/// </summary>
/// <param name="str">Unicode编码字符串</param>
/// <returns>汉字字符串</returns>
public static string ToGB2312(string str)
{
string r = "";
MatchCollection mc = RegexMatches(str, @"\\u([\w]{2})([\w]{2})", RegexOptionsCompiled | RegexOptionsIgnoreCase);
byte[] bts = new byte[2];
foreach(Match m in mc )
{
bts[0] = (byte)intParse(mGroups[2]Value, NumberStylesHexNumber);
bts[1] = (byte)intParse(mGroups[1]Value, NumberStylesHexNumber);
r += EncodingUnicodeGetString(bts);
}
return r;
}
以上就是关于Mysql数据库乱码 就是网页上存入中文,但是成功保存数据后跳转页面出现乱码,数据库里面刚刚存入的全部的内容,包括:Mysql数据库乱码 就是网页上存入中文,但是成功保存数据后跳转页面出现乱码,数据库里面刚刚存入的、关于C#向MySQL数据库存储汉字时乱码问题寻求解决方案、把数据库中的中文输出出来为什么乱码等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)