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'的一部分
答案 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));