在 SQL 数据库中保存 Base64String 结果为 NULL
Saving Base64String in SQL Database results in NULL
我正在尝试使用以下方法将图像保存到我的数据库中
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;
}
我正在将其保存到关注对象中,
public class MediaImage
{
[Key]
public Guid Id { get; set; }
[Column(TypeName = "varchar(MAX)")]
public string Image { get; set; }
public string ContentType { get; set; }
}
当我逐步执行它时,Base64ToImage 正在工作(我能够 copy/paste 将字符串返回到图像中)。
然而,当我将 MediaImage 对象保存到数据库时,Image 字段为 NULL,即使它在保存到数据库之前有一个值。
据我所知,没有抛出异常。我不确定我的数据类型是否不正确?
根据您的 images/version MSSQL 的大小,您应该 select 二进制字符串列表中的数据类型 ... https://msdn.microsoft.com/en-GB/library/ms187752.aspx
但是!在你这样做之前......阅读这个因为有时将图像存储在数据库中并不是最好的选择......
问题是我使用了错误的数据类型,将其更改为字节数组为我解决了这个问题。找到了关于这个 SO 问题的答案,它没有被标记为答案,但如果我能够弄明白,请查看 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")],或者如果您更喜欢代码映射,请将其添加到上下文 [=20] 中的 OnModelCreating 覆盖=]:
modelBuilder.Entity<Product>().Property(p => p.Image).HasColumnType("image");
我正在尝试使用以下方法将图像保存到我的数据库中
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;
}
我正在将其保存到关注对象中,
public class MediaImage
{
[Key]
public Guid Id { get; set; }
[Column(TypeName = "varchar(MAX)")]
public string Image { get; set; }
public string ContentType { get; set; }
}
当我逐步执行它时,Base64ToImage 正在工作(我能够 copy/paste 将字符串返回到图像中)。
然而,当我将 MediaImage 对象保存到数据库时,Image 字段为 NULL,即使它在保存到数据库之前有一个值。
据我所知,没有抛出异常。我不确定我的数据类型是否不正确?
根据您的 images/version MSSQL 的大小,您应该 select 二进制字符串列表中的数据类型 ... https://msdn.microsoft.com/en-GB/library/ms187752.aspx
但是!在你这样做之前......阅读这个因为有时将图像存储在数据库中并不是最好的选择......
问题是我使用了错误的数据类型,将其更改为字节数组为我解决了这个问题。找到了关于这个 SO 问题的答案,它没有被标记为答案,但如果我能够弄明白,请查看 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")],或者如果您更喜欢代码映射,请将其添加到上下文 [=20] 中的 OnModelCreating 覆盖=]:
modelBuilder.Entity<Product>().Property(p => p.Image).HasColumnType("image");