3

2つのメソッドとImage内のSQLServer列のデータ型としてSQLServer2005に画像をアップロードするWinformsアプリケーションがあります。SingleMultiple

シングルでは、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[]から正しいバイナリデータを取得する方法を見つけるのを手伝ってください

4

1 に答える 1

1

画像を Base64 文字列に変換してみてください:

// Convert byte[] to Base64 String
string base64ImageString = Convert.ToBase64String(imageBytes);

必要ないくつかの方法:

画像から Base64 文字列へ

public string ImageToBase64(Image image, 
  System.Drawing.Imaging.ImageFormat format)
{
  using (MemoryStream ms = new MemoryStream())
  {
    // Convert Image to byte[]
    image.Save(ms, format);
    byte[] imageBytes = ms.ToArray();

    // Convert byte[] to Base64 String
    string base64String = Convert.ToBase64String(imageBytes);
    return base64String;
  }
}

Base64 文字列から画像へ

public Image Base64ToImage(string base64String)
{
  // Convert Base64 String to byte[]
  byte[] imageBytes = Convert.FromBase64String(base64String);
  MemoryStream ms = new MemoryStream(imageBytes, 0, 
    imageBytes.Length);

  // Convert byte[] to Image
  ms.Write(imageBytes, 0, imageBytes.Length);
  Image image = Image.FromStream(ms, true);
  return image;
}

ここからのコード。

于 2012-12-26T07:41:53.610 に答える