如何下载Sitecore Images

时间:2015-02-05 09:19:49

标签: sitecore sitecore6

var database = Database.GetDatabase(“master”);
var images = database.SelectItems(“/sitecore/media library/your image folder/descendant::*[@@templatekey=’jpeg’]”);

foreach (var image in images)
{
var mediaItem = (MediaItem)image;
var media = MediaManager.GetMedia(mediaItem);
var stream = media.GetStream();

using (var targetStream = File.OpenWrite(Path.Combine(“your data path”, image.Name + “.jpeg” )))
{
stream.CopyTo(targetStream);
targetStream.Flush();
}
}

我是Sitecore的新手,任何人都可以帮助我如何从Sitecore下载图像到我们电脑的本地文件夹,当我搜索时,我发现了一个代码,但没有工作。错误是找不到路径'E:\ Images \ RedTorch.jpeg'的一部分

2 个答案:

答案 0 :(得分:0)

这是一篇很好的博客文章,描述了如何从媒体库中的特定文件夹下载图像:Save all images of a media library folder to disk

重要:请记住,IIS进程使用的用户必须具有对c:\tmp目录(或您使用的任何其他目录)的写访问权。

那里的代码:

var database = Database.GetDatabase("master");
var images = database.SelectItems("/sitecore/media library/your image folder/descendant::*[@@templatekey='jpeg']");

foreach (var image in images)
{
    var mediaItem = (MediaItem)image;
    var media = MediaManager.GetMedia(mediaItem);
    var stream = media.GetStream();

    using (var targetStream = File.OpenWrite(Path.Combine("c:\\tmp", image.Name + ".jpeg" )))
    {
        stream.CopyTo(targetStream);
        targetStream.Flush();
    }
}

修改

从您的评论看起来,您不想将媒体项目保存在服务器硬盘驱动器上,而是将其下载到用于浏览网站的计算机上。这是对的吗?

在这种情况下,您可以使用以下代码。它将生成所有媒体项目的zip,这些项目是所选文件夹上的直接子项,并允许用户下载此zip:

string tempFolderPath = Sitecore.Configuration.Settings.TempFolderPath;
tempFolderPath = HttpContext.Current.Server.MapPath(tempFolderPath);
string zipName = "media" + DateTime.Now.Ticks + ".zip";
ZipWriter zipWriter = new ZipWriter(Path.Combine(tempFolderPath, zipName));

var database = Database.GetDatabase("master");
var images = database.SelectItems("/sitecore/media library/your folder/*");

foreach (var image in images)
{
    if (MediaManager.HasMediaContent(image))
    {
        var mediaItem = (MediaItem) image;
        var media = MediaManager.GetMedia(mediaItem);
        var stream = media.GetStream();

        zipWriter.AddEntry(mediaItem.Name + "." + mediaItem.Extension, stream.Stream);
    }
}

zipWriter.Dispose();

HttpContext.Current.Response.Clear();
HttpContext.Current.Response.ContentType = "application/zip";
HttpContext.Current.Response.AppendHeader("Content-Disposition", string.Format("inline;filename=\"{0}\"", zipName));
HttpContext.Current.Response.StatusCode = (int)HttpStatusCode.OK;
HttpContext.Current.Response.BufferOutput = true;

using (StreamReader sr = new StreamReader(Path.Combine(tempFolderPath, zipName)))
{
    sr.BaseStream.CopyTo(HttpContext.Current.Response.OutputStream);
    HttpContext.Current.Response.Flush();
    HttpContext.Current.Response.End();
}

答案 1 :(得分:0)

您的示例中的代码看起来没问题,并且与Marek的答案大致相同,这里可能存在的问题是您使用Path.Combine来包含可能尚不存在的新文件夹(基于在您收到的错误消息上:"无法找到路径的一部分")。

如果您在写入文件之前添加此行(首先创建变量,保存最终和完整的路径字符串),您可以确保在将文件写入磁盘之前存在所有目录:

Directory.CreateDirectory(Path.GetDirectoryName(filePath));