首页 文章

在SQL数据库中保存Base64String会导致NULL

提问于
浏览
0

我试图使用以下方法将图像保存到我的数据库中

public string ImageToBase64(Image image, 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;
        }
    }

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;
    }

我将它保存到follow对象中,

public class MediaImage
{
    [Key]
    public Guid Id { get; set; }
    [Column(TypeName = "varchar(MAX)")]
    public string Image { get; set; }
    public string ContentType { get; set; }
}

当我单步执行它时,Base64ToImage正在工作(我能够将字符串复制/粘贴回图像中) .

但是,当我将MediaImage对象保存到数据库时,Image字段为NULL,即使它在保存到数据库之前有一个值 .

据我所知,没有任何例外被抛出 . 我不确定我的数据类型是否不正确?

2 回答

  • 0

    根据您的图像/ MSSQL版本的大小,您应该从二进制字符串列表中选择您的数据类型... https://msdn.microsoft.com/en-GB/library/ms187752.aspx

    但!在你这样做之前...阅读本文,因为有时在DB中存储图像不是最佳选择... https://stackoverflow.com/a/5613926/5040941

  • 0

    问题是我使用了错误的数据类型,将其更改为字节数组解决了它 . 在这个问题上找到了答案,它没有被标记为答案但是看起来Cosmin Onea提供的答案我能够弄清楚 .

    How to store images using Entity Framework Code First CTP 5?

    public class Product
    {
        public int Id { get; private set; }
    
        public string Name { get; set; }
    
        public byte[] ProductImage { get; set; }
    }
    

    这就是它 . 如果不映射属性,则约定它将映射到varbinary(max) . 如果数据库中有图像列,则只需在ProductImage属性上添加[Column(TypeName =“image”)],或者如果您更喜欢代码映射,请将其添加到上下文类中的OnModelCreating覆盖:

    modelBuilder.Entity<Product>().Property(p => p.Image).HasColumnType("image");
    

相关问题