2

我将图像存储在数据库中,在存储它们之前,我正在调整它们的大小。

但是,调整大小不会压缩图像。流是相同的流。我也希望能够压缩图像。

如何压缩以流形式存储在数据库中并返回到请求的图像,如下所示?

    public ActionResult ViewImage(int id, string imageType ="image")
    {
        ContestImage contestImage = GetContestImage(id);

        byte[] fileContent;
        string mimeType;
        string fileName;

        if (imageType == "thumb")
        {
            fileContent = contestImage.ThumbNail.Image;
            mimeType = contestImage.ThumbNail.ImageMimeType;
            fileName = contestImage.ThumbNail.ImageFileName;
        }
        else if (imageType == "image")
        {
            fileContent = contestImage.Image.Image;
            mimeType = contestImage.Image.ImageMimeType;
            fileName = contestImage.Image.ImageFileName;
        }


        return File(fileContent, mimeType, fileName);
    }

public class UserImage
{
    public virtual int Id { set; get; }
    public virtual byte[] Image { set; get; }
    public virtual string ImageMimeType { set; get; }
    public virtual string ImageFileName { set; get; }
}

ContestImage 有 UserImage 对象。

4

2 回答 2

0

在从数据库中存储和检索图像时,您是否尝试过使用GZipStream ?

于 2012-05-19T20:49:41.497 回答
0

我想到了两种主要方法:

  • 将数据加载为图像并以压缩文件格式(例如 png 或 jpeg)将其序列化(到内存流)

  • 通过压缩流(例如 DeflateStream)将数据序列化(到内存流)。

Once you have the data in a MemoryStream, you can use MemoryStream.ToArray() to convert it back to a straight byte[] buffer to pass to your database.

于 2012-05-19T20:49:54.123 回答