2つのメソッドとImage
内のSQLServer列のデータ型としてSQLServer2005に画像をアップロードするWinformsアプリケーションがあります。Single
Multiple
シングルでは、C#からSPにバイナリイメージとしてパラメータを送信します。
しかし、複数の場合、それらをXMLプレーンテキストとしてDBに送信し、SP内でそれらを使用して画像に変換する必要があります
convert(image, @myimageFromXML, 2)
私は他のウェブサイトのような多くの機能を試しました
public static string ByteArrayToString(byte[] ba)
{
StringBuilder hex = new StringBuilder(ba.Length * 2);
foreach (byte b in ba)
hex.AppendFormat("{0:x2}", b);
return hex.ToString();
}
public static string ByteArrayToString(byte[] ba)
{
string hex = BitConverter.ToString(ba);
return hex.Replace("-", "");
}
public static string ByteArrayToString(byte[] Bytes)
{
char[] hexes = new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
char[] Result = new char[Bytes.Length << 1];
int Offset = 0;
for (int i = 0; i != Bytes.Length; i++)
{
Result[Offset++] = hexes[Bytes[i] >> 4];
Result[Offset++] = hexes[Bytes[i] & 0x0F];
}
return new string(Result);
}
public static String ByteArrayToString(byte[] Source)
{
return "0x" + BitConverter.ToString(Source).Replace("-", "");
}
public static string ByteArrayToString(byte[] barray)
{
char[] c = new char[barray.Length * 2];
byte b;
for (int i = 0; i < barray.Length; ++i)
{
b = ((byte)(barray[i] >> 4));
c[i * 2] = (char)(b > 9 ? b + 0x37 : b + 0x30);
b = ((byte)(barray[i] & 0xF));
c[i * 2 + 1] = (char)(b > 9 ? b + 0x37 : b + 0x30);
}
return new string(c);
}
しかし、それらのすべてが正しくないデータを返し、画像としてレンダリングできないため、表示できません
単一のドキュメントアップロード内の私の正しい画像は、保存されたバイナリ画像で始まります
0x49492A008C040600803FA04FF004160D0784..........
しかし、複数のアップロードで保存された間違ったデータはで始まります
0x310033003700380030003700380037.............
XMLとしてSQLServerにテキストとして送信するためにC#byte[]から正しいバイナリデータを取得する方法を見つけるのを手伝ってください