Как я могу показать изображение из базы данных в mysql (blob), в элемент управления «Изображение» на веб-странице

0

Я пытаюсь сделать тестовый сайт, где я могу загрузить изображение и некоторый текст в базе данных и получить изображение в режиме предварительного просмотра изображения. Мне удалось сохранить эти элементы как varchar и blob (MEDIUMBLOB). (MySql)

Однако у меня возникли проблемы с попыткой показать сохраненное изображение в элементе управления Image.

здесь код:

MySqlConnection conn;
MySqlCommand comand;
String queryStr;
MySqlDataAdapter daa;
protected void Button1_Click(object sender, EventArgs e)
{
    HttpPostedFile postedFile = FileUpload1.PostedFile;
    string fileName = Path.GetFileName(postedFile.FileName);
    string fileExtension = Path.GetExtension(fileName);
    int fileSize = postedFile.ContentLength;
    try
    {
        if (fileExtension.ToLower()==".jpg" || fileExtension.ToLower() == ".png")
        {
            AgregarCiudad();//add city method in spanish
            Response.Write("Exito");
            MostrarImagen();//show image method also in spanish lol
        }
        else
        {
            Response.Write("Solo Imagenes .jpg o .png de 15 megabites o menos.");
        }

    }
    catch (FileNotFoundException fFileNotFound)
    {
        //log the exception the specified fFileNotFound variable has to be put in a string, label or response.
        Response.Write("Error." + fFileNotFound.Message);

    }
    catch (Exception)
    {
        Response.Write("Error");
    }
}
private void AgregarCiudad()
{
    String connString = System.Configuration.ConfigurationManager.ConnectionStrings["WebAppConnString"].ToString();
    conn = new MySqlConnection(connString);
    conn.Open();
    queryStr = "";
    queryStr = "INSERT INTO testingdb.country (Relation, Name, ImageStock)" +
        "VALUES(?Relation, ?Name, ?ImageStock)";
    comand = new MySqlCommand(queryStr, conn);
    comand.Parameters.AddWithValue("?Relation", TextBox1.Text);
    comand.Parameters.AddWithValue("?Name", TextBox2.Text);
    comand.Parameters.AddWithValue("?ImageStock", FileUpload1);

    comand.ExecuteReader();
    conn.Close();
}

как вы можете видеть здесь, я не знаю, что еще делать сейчас, что можно сделать, чтобы этот метод отображал недавно сохраненное изображение в элементе управления Image (Image1)?

private void MostrarImagen()
{
    String selectQuery = "SELECT ImageStock FROM testingdb.country WHERE 
Name ='" + TextBox2.Text + "'";
    comand = new MySqlCommand(selectQuery, conn);
    MySqlDataReader reader;
    reader = comand.ExecuteReader();
    Image1.ImageUrl = selectQuery;
    conn.Close();

}
Теги:
web

1 ответ

0
Лучший ответ

Я предполагаю, что вы получаете данные blob из базы данных. После этого попробуйте что-то вроде этого:

string base64String = Convert.ToBase64String(your blob);
Image1.ImageUrl = "data:image/png;base64," + base64String;
  • 0
    что ты имеешь в виду (твой блоб)? что я могу туда положить?
  • 1
    aspsnippets.com/Articles/… Это может помочь вам
Показать ещё 1 комментарий

Ещё вопросы

Сообщество Overcoder
Наверх
Меню