C# Byte[]使用总结

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# Byte[]使用总结相关的知识,希望对你有一定的参考价值。

参考技术A 01,C# string类型转成byte[]:

Byte[] byteArray = System.Text.Encoding.Default.GetBytes ( str );

02, C# byte[]转成string:

stringstr = System.Text.Encoding.Default.GetString ( byteArray );

03,C# string类型转成ASCIIbyte[]:

("01"转成byte[] =newbyte[]0x30,0x31)

byte[] byteArray = System.Text.Encoding.ASCII.GetBytes ( str );

04,C# ASCIIbyte[]转成string:

(byte[] = new byte[] 0x30, 0x31 转成"01")

string str = System.Text.Encoding.ASCII.GetString ( byteArray );

05, C# byte[]转16进制格式string:

new byte[] 0x30, 0x31转成"3031":

public static string ToHexString ( byte[] bytes ) // 0xae00cf => "AE00CF "



string hexString = string.Empty;

if ( bytes != null )

               

StringBuilder strB = new StringBuilder ();

for ( int i = 0; i < bytes.Length; i++ )

                   

strB.Append ( bytes[i].ToString ( "X2" ) );               

               

hexString = strB.ToString ();           

return hexString;       



C# byte[]数组截取:

byte[] data= new byte[]1,2,3,4,5,6,7,8,9;

截取2位:BitConverter.ToInt16(data,3);//3表示从第三个位置开始

截取4位:BitConverter.ToInt32(data,3);

截取8位:BitConverter.ToInt64(data,3);

如果截取的数量不规则:data.Skip(5).Take(3).ToArray(); //表示从第五个位置截取三个字节

                                        data.Skip(4).ToArray();                //表示从第四个位置截取到最后

(1)

byte[] data = new byte[]0,1,2,3,4,5,6,7,8,9;

byte[] data1 = new byte[data.length];

for(int i=0;i<data1.length;i++)

        data1[i] = data[i];



(2)全部复制

byte[] data = new byte[]0,1,2,3,4,5,6,7,8,9;

byte[] data1 = new byte[data.length];

Array.Copy(data,data1,data.length);//源数据data,目标数据data1,复制长度data.length

(3)全部复制

byte[] data = new byte[]0,1,2,3,4,5,6,7,8,9;

byte[] data1;

data1 = (byte[])data .Clone();

(4)深度复制

byte[] srcArray = new byte[] 0x01, 0x02, 0x03, 0x04 ;

byte[] dstArray = new byte[srcArray.Length];

Buffer.BlockCopy(srcArray, 0, dstArray, 0, srcArray.Length);//源数据srcArray , 起始位置0,目标数组dstArray ,开始位置0,                                                                                                      多少长度 srcArray.Length

byte[] data = new byte[]0,1,2,3,4,5,6,7,8,9;

(1)删除指定位置数量的数据

Array.Clear(data,0,5); //data 从起始位置0, 删除5个位置

(2)删除指定的数据--返回byte[] 空间减少

///

/// 去掉byte[] 中特定的byte

///

/// 需要处理的byte[]

/// byte[] 中需要除去的特定 byte (此处: byte cut = 0x00 ;)

///

public static byte[] ByteCut(byte[] b, byte cut)



var list = new List();

list.AddRange(b);

for (var i = list.Count - 1; i >= 0; i--)



if (list[i] == cut)

list.RemoveAt(i);



var lastbyte = new byte[list.Count];

for (var i = 0; i < list.Count; i++)



lastbyte[i] = list[i];



return lastbyte;



(3)清空byte[]

byte[] data = new byte[50];

data = new byte[50];//新new 出来则原来空间数据清除

C# mysql 使用 Byte[] 将文件插入数据库

【中文标题】C# mysql 使用 Byte[] 将文件插入数据库【英文标题】:C# mysql insert file into database using Byte[] 【发布时间】:2012-12-18 19:04:08 【问题描述】:

我正在 AsyncUpload 集合中执行一个简单的 foreach 循环到 Byte[] 并尝试将其插入数据库。

 foreach (UploadedFile file in AsyncUpload1.UploadedFiles)
        

            string[] splitFileExt = file.FileName.Split('.');
            List<string> CommandArgs = new List<string>();
            CommandArgs.Add("IID|" + Request.QueryString["InstructorID"]);
            CommandArgs.Add("FName|" + file.FileName);
            CommandArgs.Add("FTitle|" + file.FileName);
            CommandArgs.Add("FType|" + file.ContentType);
            CommandArgs.Add("FExtension|" + splitFileExt[1]);
            CommandArgs.Add("FSize|" + file.ContentLength.ToString());
            byte[] b = StaticControlCreationClass.ReadToEnd(file.InputStream);
            MySQLProcessing.MySQLProcessor.MySQL_UploadFile(b, "fileupload", CommandArgs, mysqlCon);

        



public static void MySQL_UploadFile(byte[] value, string MYSQLCommand, List<string> CommandArgs, MySqlConnection con)
    
        MySqlCommand cmd = new MySqlCommand(MYSQLCommand, con);
        cmd.Parameters.AddWithValue("FContent", value);
        foreach (string args in CommandArgs)
        
            string[] splitArgs = args.Split('|');
            cmd.Parameters.AddWithValue(splitArgs[0], splitArgs[1].Trim());
        
        cmd.ExecuteNonQuery();

    

然后这里是存储过程

如果存在文件上传,则删除程序; 创建过程文件上传`( IID 整数, TValue varchar(250), FName varchar(250), FType varchar(15), FSize varchar(45), FContent longblob, FExtension varchar(10)) 开始 SET @IID = IID; SET @TValue = TValue; SET @FName = FName; SET @FType = FType; 设置@FSize = FSize; SET @FExtension = FExtension; SET @FContent = FContent; 插入到 tblfiles(rID, 标题, 文件名, 文件类型, 文件大小, 文件_内容, 文件扩展名) 值(@IID, @T值, @F名称, @F类型, @FS大小, @F内容, @FExtension); 结尾

我不断收到You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'fileupload' at line 1@cmd.ExecuteNonQuery();

感谢任何帮助。

【问题讨论】:

【参考方案1】:

我错过了分类器说它是一个存储过程

cmd.CommandType = CommandType.StoredProcedure;

【讨论】:

以上是关于C# Byte[]使用总结的主要内容,如果未能解决你的问题,请参考以下文章

C#调用dll时的类型转换总结

高难度问题,C#结构体的封送 的使用经验总结

C#语言数据总结

C#流总结(文件流内存流网络流BufferedStreamStreamReader/StreamWriterTextReader/TextWriter)

C#流总结(文件流内存流网络流BufferedStreamStreamReader/StreamWriterTextReader/TextWriter)

c#中如何将byte数组转换成string从而在textbox中显示出来?