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#流总结(文件流内存流网络流BufferedStreamStreamReader/StreamWriterTextReader/TextWriter)
C#流总结(文件流内存流网络流BufferedStreamStreamReader/StreamWriterTextReader/TextWriter)