This topic describes how to work with media types and BLOB providers in Episerver. Media (such as files) are treated as any other content type, but have an associated binary data that is stored using BLOB providers, which are optimized for storing streams of data.
Examples
The following example defines a simple content type that is used in the examples that follow it:
C#
[ContentType]
public class GenericFile : MediaData
{
public string Description { get; set; }
}
The following example creates a new file and defines a simple text file with the message Hello world:
C#
public void Uploading_a_file()
{
var contentRepository = ServiceLocator.Current.GetInstance<IContentRepository>();
var blobFactory = ServiceLocator.Current.GetInstance<BlobFactory>();
var file1 = contentRepository.GetDefault<GenericFile>(SiteDefinition.Current.GlobalAssetsRoot);
file1.Name = "Readme.txt";
var blob = blobFactory.CreateBlob(file1.BinaryDataContainer, ".txt");
using (var s = blob.OpenWrite())
{
StreamWriter w = new StreamWriter(s);
w.WriteLine("Hello world");
w.Flush();
}
file1.BinaryData = blob;
var file1ID = contentRepository.Save(file1, SaveAction.Publish);
}
The following example creates a location where the actual file type is resolved during runtime from extension:
C#
public void Uploading_a_media_from_extension()
{
var contentRepository = ServiceLocator.Current.GetInstance<IContentRepository>();
var contentTypeRepository = ServiceLocator.Current.GetInstance<IContentTypeRepository>();
var mediaDataResolver = ServiceLocator.Current.GetInstance<ContentMediaResolver>();
var blobFactory = ServiceLocator.Current.GetInstance<BlobFactory>();
var mediaType = mediaDataResolver.GetFirstMatching(".txt");
var contentType = contentTypeRepository.Load(mediaType);
var media = contentRepository.GetDefault<MediaData>(SiteDefinition.Current.GlobalAssetsRoot, contentType.ID);
media.Name = "Readme.txt";
var blob = blobFactory.CreateBlob(media.BinaryDataContainer, ".txt");
using (var s = blob.OpenWrite())
{
StreamWriter w = new StreamWriter(s);
w.WriteLine("Hello world");
w.Flush();
}
media.BinaryData = blob;
var file1ID = contentRepository.Save(media, SaveAction.Publish);
}
The following example updates an existing file with new metadata:
C#
public void UpdatingMetaData_of_a_file()
{
var contentRepository = ServiceLocator.Current.GetInstance<IContentRepository>();
var blobFactory = ServiceLocator.Current.GetInstance<BlobFactory>();
var fileID = new ContentReference(444);
var file1 = contentRepository.Get<GenericFile>(fileID).CreateWritableClone() as GenericFile;
file1.Description = "My description";
var file1ID = contentRepository.Save(file1, SaveAction.Publish);
}
The following example updates an existing file with new binary data:
C#
public void UpdatingBinary_of_a_file()
{
var contentRepository = ServiceLocator.Current.GetInstance<IContentRepository>();
var blobFactory = ServiceLocator.Current.GetInstance<BlobFactory>();
var fileID = new ContentReference(444);
var file1 = contentRepository.Get<GenericFile>(fileID).CreateWritableClone() as GenericFile;
var blob = blobFactory.CreateBlob(file1.BinaryDataContainer, ".txt");
using (var s = blob.OpenWrite())
{
StreamWriter w = new StreamWriter(s);
w.WriteLine("Hello world");
w.Flush();
}
file1.BinaryData = blob;
var file1ID = contentRepository.Save(file1, SaveAction.Publish);
}
See BLOB storage and BLOB providers to change storage model for media, such as BLOB provider.
Do you find this information helpful? Please log in to provide feedback.