Как конвертировать BLOB в изображениеC#

Место общения программистов C#
Ответить
Anonymous
 Как конвертировать BLOB в изображение

Сообщение Anonymous »

У меня проблема с отображением изображения, хранящегося в моей базе данных MySQL.
Я не знаю, успешно ли я его сохранил, но используя эту функцию, которая преобразует изображение в файл больших двоичных объектов, вот функция:

private byte[] imageToByteArray(Image imageIn)
{
MemoryStream ms = new MemoryStream();
imageIn.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
return ms.ToArray();
}


Когда я проверяю свою базу данных, там написано BLOB с синим цветом. Теперь я хотел бы отобразить изображение в моем PictureBox. У меня также есть функция для преобразования массива байтов в изображение.

private Image byteArrayToImage(byte[] byteArrayIn)
{
MemoryStream ms = new MemoryStream(byteArrayIn);
ms.Position = 0;
Image returnImage = Image.FromStream(ms);
return returnImage;
}


Когда я запускаю приложение, оно говорит:


ArgumentException не поддерживается, параметр недопустим


Я пробовал использовать этот синтаксис:

pictureBox1.Image = byteArrayToImage(dr["img"] as byte[]);


Или я думаю, стоит ли мне сначала преобразовать BLOB в байтовый массив? затем используйте функцию для преобразования массива байтов в изображение?

когда я нажимаю на имя, оно должно отображать информацию, к сожалению, я получаю исключение аргумента..

int i = dataGridView1.SelectedCells[0].RowIndex;
string firstname = dataGridView1.Rows.Cells[0].Value.ToString();
string lastname = dataGridView1.Rows.Cells[1].Value.ToString();

Connection connect = new Connection();
MySqlConnection mySqlConnect = new MySqlConnection(connect.connString());
mySqlConnect.Open();

string s = "SELECT * FROM tbl_contacts WHERE username = '" + label1.Text + "' and (fname = '" + firstname + "' and lname = '" + lastname + "')";

MySqlCommand mySQL = new MySqlCommand(s, mySqlConnect);
mySQL.ExecuteNonQuery();
MySqlDataReader dr = mySQL.ExecuteReader();

if (dr.HasRows)
{
dr.Read();
txtFname.Text = dr["fname"].ToString();
txtLname.Text = dr["lname"].ToString();
txtBday.Text = dr["birthday"].ToString();
txtEmail.Text = dr["email"].ToString();
txtMobile.Text = dr["mobile"].ToString();
txtAddress.Text = dr["address"].ToString();
txtNotes.Text = dr["notes"].ToString();
pictureBox1.Image = byteArrayToImage(dr["img"] as byte[]);
}


Подробнее здесь: https://stackoverflow.com/questions/143 ... b-to-image
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»