在C#和MySQL中存取中文字符时避免乱码的方法
作者:goldensun 发布时间:2024-01-15 13:59:02
标签:C#,MySQL
当用到socket来进行网络程序开发时,大多数情况下会遇到中文字符的发送与接收,这时若对发送的字符串用默认的方式进行处理,则一般会得到一堆乱码。
由于中文字符采用双字节表示,所以对含有中文的字符串的处理一定要按UNICODE编码方式进行处理,也就是说,使用socket发送中文字串时要事先将字串转成UNICODE格式的。
下面是简单的socket通信的代码。
//服务端代码
try
{
IPAddress MyIP = IPAddress.Parse(“127.0.0.1″);
TcpListener MyListener = new TcpListener(MyIP, Convert.ToInt16(“1235″));
MyListener.Start();
Socket MySocket = MyListener.AcceptSocket();
byte[] MyData = new byte[256];
MySocket.Receive(MyData);
this.richTextBox1.AppendText(System.Text.Encoding.Unicode.GetString(MyData));
UnicodeEncoding MyInfo = new UnicodeEncoding();
MySocket.Send(MyInfo.GetBytes(“From Server:你好!我是服务器”));
}
catch (Exception ex)
{
MessageBox.Show(ex.Message,“信息提示”,MessageBoxButtons.OK,MessageBoxIcon.Information);
}
//客户端代码
try
{
TcpClient MyClient = new TcpClient();
MyClient.Connect(“127.0.0.1″, Convert.ToInt16(“1235″));
Stream MyStream = MyClient.GetStream();
UnicodeEncoding MyInfo = new UnicodeEncoding();
byte[] MyData = new byte[256];
byte[] MySendByte = MyInfo.GetBytes(“From Client:你好!我是客户端”);
MyStream.Write(MySendByte, 0, MySendByte.Length);
MyStream.Read(MyData, 0, 256);
this.richTextBox1.AppendText(System.Text.Encoding.Unicode.GetString(MyData));
}
catch(Exception ex)
{
MessageBox.Show(ex.Message,“信息提示”,MessageBoxButtons.OK,MessageBoxIcon.Information);
}
此外,数据库中中文的存取也是一件令人头疼的事,其实要解决这个问题很简单,下面是一段SQL Server的代码:
try
{
SqlConnection MyConnect = new SqlConnection(m_ConnectionStrings);
//插入新纪录
string MySQL = string.Format(“INSERT INTO [BSM_SystemServiceInfoTable] VALUES ({0},N'{1}',N'{2}',N'{3}',N'{4}')”,AgentID, data[1], data[2], data[3], data[0]);
MyCommand = new SqlCommand(MySQL, MyConnect);
MyCommand.Connection.Open();
MyCommand.ExecuteNonQuery();
MyCommand.Connection.Close();
}
catch (System.Exception e)
{
MessageBox.Show(e.ToString ());
}
可以看到,SQL脚本命令中,所有的字符串参数前多了一个字符“N”,这个字符即声明用UNICODE方式编码,当然,要注意的就是,若字段的值可能含有中文时,必须将该字段类型声明为nchar、nvarchar、ntext,这里的n表示的意思是一样的。


猜你喜欢
- 话不多说 直接上代码<el-upload :action="actionUrl&q
- 1、引言续上一篇《一行代码,导入Python所有库》不知道是不是都跟小鱼一样,把剩下的时间来学(撩)习(妹)。为了体现小鱼在懒上的造就,小鱼
- 有些人说py中有两个函数可以实现对所有函数的了解以及使用,其中之一,就是我们今天要讲解的help函数。有些小伙伴可能比较陌生,但是另一个函数
- Python 的 Queue 模块中提供了同步的、线程安全的队列类,包括FIFO(先入先出)队列Queue,LIFO(后入先出)队列Lifo
- 当讨论Request对象内容时,要研究的集合之一就是ServerVariables集合。这个集合包含了两种值的结合体,一种是随同
- 前言之前接触到的数据库死锁,都是批量更新时加锁顺序不一致而导致的死锁,但是上周却遇到了一个很难理解的死锁。借着这个机会又重新学习了一下mys
- Node被设计用来高效的处理I/O操作,但是你应该知道,有些类型的程序并不适合这种模式。比如,如果你打算用Node处理一个CPU密集的任务,
- 目录前言map 并发操作出现问题sync.Map 解决并发操作问题计算 map 长度计算 sync.Map 长度前言在 Golang 中 m
- 从本地文件夹中选取一张图片并在canvas上显示from tkinter import *from tkinter import filed
- javascript基础教程算术运算符运算符运算符说明示例示例说明+加法x+y如果x为整数2,y为整数5, x+y等于7如果x为字符串&qu
- 大多的MySQL都是装在Linux上的,而我们的本机上一般都会装MySQL-Front.那如何用MySQL-Front连接远端Linux系统
- 在服务器上训练的网络放到本地台式机进行infer,结果出现报错:AssertionError: Invalid device id仔细检查后
- XML的嵌套处理 一般情况下,我们从数据库中查询得到的结果集可能很大,所以从服务器返回到客户端时,数据会被分成若干个页面分别进行传递。此时,
- 本文实例讲述了Python进阶之使用selenium爬取淘宝商品信息功能。分享给大家供大家参考,具体如下:# encoding=utf-8_
- 需求:给定一个数组和一个正整数,要求把数组分割成多个正整数大小的数组,如果不够分,则最后一个数组分到剩余的所有元素。示例1:数组:[1, 2
- 那么,现在如果给出一个权限编号,要去检索出用后这个权限的用户集合,就会需要在逗号分隔的多个权限编号中去匹配给出的这个权限编号。如果使用lik
- 方法1: 用file_get_contents 以get方式获取内容:<?php$url='https://www.aspxh
- 认为整理的还比较详细的,亲们,就快点收藏起来吧!PHP系统类函数assert函数:检查assertion声明是否错误extension_lo
- 这几天看了Amy老师的用javascript实现瀑布流,我跟着把代码敲出来。发现这样写只能第一次载入时适应屏幕,以后改变窗口大小就不能做到自
- 一、基本介绍在编程中,程序员会经常使用到日期相关的函数,比如:统计某段代码执行花费的时间等等。在 Go 中,开发者为我们提供了 time 包