Running the sample

Please follow the steps below.

Step 1: Open the CSAzureServeFilesFromBlobStorage.sln as Administrator. Expand the CSAzureServeFilesFromBlobStorage application and set CSAzureServeFilesFromBlobStorage azure application as the startup project, press F5 to display Default.aspx page.

Step 2: Please add your Windows Azure Storage Account and Key in the Windows Azure settings, "StorageConnections". If you do not have one, please use Windows Azure Storage Emulator.  You will see a web page with two unavailable links on it. Please click the link "Add default resources page" to redirect to default resources adding page.

Step 3:  Click the "Click to upload the default resources" button to upload your resources to Windows Azure Blob Storage and Table Storage. You can find "Microsoft.jpg, MSDN.jpg and Site.css" in the "Files" folder. These files will be uploaded to the blob container and their information will be stored in table storage.

Step 4: The files have been uploaded now. You can go to Microsoft Windows Azure Management Portal or use Azure Storage Explore tool to view your resources. The default blob container name is "container" and default table name is "files".

Step 5: Go back to the Default.aspx page. You will find the uploaded resources appear on it. Click the link to view them.

Step 6: In this sample, you can access jpg and css files (also including .aspx files). Files of other types, such as .htm files, cannot be reached.

Step 7: Validation finished.

Using the Code

Step 1. Create a C# "Windows Azure Project" in Visual Studio 2012. Name it as "CSAzureServeFilesFromBlobStorage". Add a Web Role and name it as "ServeFilesFromBlobStorageWebRole"; add a class library and name it as "TableStorageManager". Make sure the class library's target framework is .NET Framework 4.5 (Not .NET Framework 4.5 Client Profile).

Step 2. Add 3 class files in TableStorageManager class library, which is used to package the bottom table storage methods. Try to add Windows Azure references and Data Service client reference.

Microsoft.WindowsAzure.Diagonostics

Microsoft.WindowsAzure.ServiceRuntime

Microsoft.WindowsAzure.StorageClient

System.Data.Service.Client

The FileEntity class is a table storage entity class; it includes some basic properties. The FileContext class is used to create queries for table services. You can also add paging method for table storage. The FileDataSource package the bottom layer methods (about cloud account, TableServiceContext, credentials, etc)

C#

Edit|Remove

csharp

public class FileDataSource

{

private static CloudStorageAccount account;

private FileContext context;

public FileDataSource()

{

// Create table storage client via cloud account.

account = CloudStorageAccount.FromConfigurationSetting("StorageConnections");

CloudTableClient client = account.CreateCloudTableClient();

client.CreateTableIfNotExist("files");

// Table context properties.

context = new FileContext(account.TableEndpoint.AbsoluteUri, account.Credentials);

context.RetryPolicy = RetryPolicies.Retry(3, TimeSpan.FromSeconds(1));

context.IgnoreResourceNotFoundException = true;

context.IgnoreMissingProperties = true;

}

/// <summary>

/// Get all entities method.

/// </summary>

/// <returns></returns>

public IEnumerable<FileEntity> GetAllEntities()

{

var list = from m in this.context.GetEntities

select m;

return list;

}

/// <summary>

/// Get table rows by partitionKey.

/// </summary>

/// <param name="partitionKey"></param>

/// <returns></returns>

public IEnumerable<FileEntity> GetEntities(string partitionKey)

{

var list = from m in this.context.GetEntities

where m.PartitionKey == partitionKey

select m;

return list;

}

/// <summary>

/// Get specify entity.

/// </summary>

/// <param name="partitionKey"></param>

/// <param name="fileName"></param>

/// <returns></returns>

public FileEntity GetEntitiesByName(string partitionKey, string fileName)

{

var list = from m in this.context.GetEntities

where m.PartitionKey == partitionKey && m.FileName == fileName

select m;

if (list.Count() > 0)

return list.First<FileEntity>();

else

return null;

}

/// <summary>

/// Add an entity.

/// </summary>

/// <param name="entity"></param>

public void AddFile(FileEntity entity)

{

this.context.AddObject("files", entity);

this.context.SaveChanges();

}

/// <summary>

/// Make a judgment to check if file is exists.

/// </summary>

/// <param name="filename"></param>

/// <param name="partitionKey"></param>

/// <returns></returns>

public bool FileExists(string filename, string partitionKey)

{

IEnumerable<FileEntity> list = from m in this.context.GetEntities

where m.FileName == filename && m.PartitionKey == partitionKey

select m;

if (list.Count()>0)

{

return true;

}

else

{

return false;

}

}

}

public class FileDataSource

{

private static CloudStorageAccount account;

private FileContext context;

public FileDataSource()

{

// Create table storage client via cloud account.

account = CloudStorageAccount.FromConfigurationSetting("StorageConnections");

CloudTableClient client = account.CreateCloudTableClient();

client.CreateTableIfNotExist("files");

// Table context properties.

context = new FileContext(account.TableEndpoint.AbsoluteUri, account.Credentials);

context.RetryPolicy = RetryPolicies.Retry(3, TimeSpan.FromSeconds(1));

context.IgnoreResourceNotFoundException = true;

context.IgnoreMissingProperties = true;

}

/// <summary>

/// Get all entities method.

/// </summary>

/// <returns></returns>

public IEnumerable<FileEntity> GetAllEntities()

{

var list = from m in this.context.GetEntities

select m;

return list;

}

/// <summary>

/// Get table rows by partitionKey.

/// </summary>

/// <param name="partitionKey"></param>

/// <returns></returns>

public IEnumerable<FileEntity> GetEntities(string partitionKey)

{

var list = from m in this.context.GetEntities

where m.PartitionKey == partitionKey

select m;

return list;

}

/// <summary>

/// Get specify entity.

/// </summary>

/// <param name="partitionKey"></param>

/// <param name="fileName"></param>

/// <returns></returns>

public FileEntity GetEntitiesByName(string partitionKey, string fileName)

{

var list = from m in this.context.GetEntities

where m.PartitionKey == partitionKey && m.FileName == fileName

select m;

if (list.Count() > 0)

return list.First<FileEntity>();

else

return null;

}

/// <summary>

/// Add an entity.

/// </summary>

/// <param name="entity"></param>

public void AddFile(FileEntity entity)

{

this.context.AddObject("files", entity);

this.context.SaveChanges();

}

/// <summary>

/// Make a judgment to check if file is exists.

/// </summary>

/// <param name="filename"></param>

/// <param name="partitionKey"></param>

/// <returns></returns>

public bool FileExists(string filename, string partitionKey)

{

IEnumerable<FileEntity> list = from m in this.context.GetEntities

where m.FileName == filename && m.PartitionKey == partitionKey

select m;

if (list.Count()>0)

{

return true;

}

else

{

return false;

}

}

}

Step 3. Then we need add a class in ServeFilesFromBlobStorageWebRole project as an HttpModuler to check the types of requested files and access the files in Blob Storage.

C#

Edit|Remove

csharp

public void Init(HttpApplication context)

{

context.BeginRequest += new EventHandler(this.Application_BeginRequest);

}

/// <summary>

/// Check file types and request it by cloud blob API.

/// </summary>

/// <param name="source"></param>

/// <param name="e"></param>

private void Application_BeginRequest(Object source,EventArgs e)

{

string url = HttpContext.Current.Request.Url.ToString();

string fileName = url.Substring(url.LastIndexOf('/') + 1).ToString();

string extensionName = string.Empty;

if (fileName.Substring(fileName.LastIndexOf('.') + 1).ToString().Equals("aspx"))

{

return;

}

if (!fileName.Equals(string.Empty))

{

extensionName = fileName.Substring(fileName.LastIndexOf('.') + 1).ToString();

if (!extensionName.Equals(string.Empty))

{

string contentType = this.GetContentType(fileName);

if (contentType.Equals(string.Empty))

{

HttpContext.Current.Server.Transfer("NoHandler.aspx");

};

{

FileDataSource dataSource = new FileDataSource();

string paritionKey = this.GetPartitionName(extensionName);

if (String.IsNullOrEmpty(paritionKey))

{

HttpContext.Current.Server.Transfer("NoHandler.aspx");

}

FileEntity entity = dataSource.GetEntitiesByName(paritionKey, "Files/" + fileName);

if (entity != null)

HttpContext.Current.Response.Redirect(entity.FileUrl);

else

HttpContext.Current.Server.Transfer("NoResources.aspx");

}

}

}

}

/// <summary>

/// Get file's Content-Type.

/// </summary>

/// <param name="filename"></param>

/// <returns></returns>

public string GetContentType(string filename)

{

string res = string.Empty;

switch (filename.Substring(filename.LastIndexOf('.') + 1).ToString().ToLower())

{

case "jpg":

res = "image/jpg";

break;

case "css":

res = "text/css";

break;

}

return res;

}

/// <summary>

/// Get file's partitionKey.

/// </summary>

/// <param name="extensionName"></param>

/// <returns></returns>

public string GetPartitionName(string extensionName)

{

string partitionName = string.Empty;

switch(extensionName)

{

case "jpg":

partitionName = "image";

break;

case "css":

partitionName = "css";

break;

}

return partitionName;

}

public void Init(HttpApplication context)

{

context.BeginRequest += new EventHandler(this.Application_BeginRequest);

}

/// <summary>

/// Check file types and request it by cloud blob API.

/// </summary>

/// <param name="source"></param>

/// <param name="e"></param>

private void Application_BeginRequest(Object source,EventArgs e)

{

string url = HttpContext.Current.Request.Url.ToString();

string fileName = url.Substring(url.LastIndexOf('/') + 1).ToString();

string extensionName = string.Empty;

if (fileName.Substring(fileName.LastIndexOf('.') + 1).ToString().Equals("aspx"))

{

return;

}

if (!fileName.Equals(string.Empty))

{

extensionName = fileName.Substring(fileName.LastIndexOf('.') + 1).ToString();

if (!extensionName.Equals(string.Empty))

{

string contentType = this.GetContentType(fileName);

if (contentType.Equals(string.Empty))

{

HttpContext.Current.Server.Transfer("NoHandler.aspx");

};

{

FileDataSource dataSource = new FileDataSource();

string paritionKey = this.GetPartitionName(extensionName);

if (String.IsNullOrEmpty(paritionKey))

{

HttpContext.Current.Server.Transfer("NoHandler.aspx");

}

FileEntity entity = dataSource.GetEntitiesByName(paritionKey, "Files/" + fileName);

if (entity != null)

HttpContext.Current.Response.Redirect(entity.FileUrl);

else

HttpContext.Current.Server.Transfer("NoResources.aspx");

}

}

}

}

/// <summary>

/// Get file's Content-Type.

/// </summary>

/// <param name="filename"></param>

/// <returns></returns>

public string GetContentType(string filename)

{

string res = string.Empty;

switch (filename.Substring(filename.LastIndexOf('.') + 1).ToString().ToLower())

{

case "jpg":

res = "image/jpg";

break;

case "css":

res = "text/css";

break;

}

return res;

}

/// <summary>

/// Get file's partitionKey.

/// </summary>

/// <param name="extensionName"></param>

/// <returns></returns>

public string GetPartitionName(string extensionName)

{

string partitionName = string.Empty;

switch(extensionName)

{

case "jpg":

partitionName = "image";

break;

case "css":

partitionName = "css";

break;

}

return partitionName;

}

Step 4. Add a Default web page to show links of some examples, and add a FileUploadPage to upload some default resources to Storage for testing.

C#

Edit|Remove

csharp

public partial class FileUploadPage : System.Web.UI.Page

{

private static CloudStorageAccount account;

public List<FileEntity> files = new List<FileEntity>();

protected void Page_Load(object sender, EventArgs e)

{

account = CloudStorageAccount.FromConfigurationSetting("StorageConnections");

}

/// <summary>

/// Upload existing resources. ("Files" folder)

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

protected void btnUpload_Click(object sender, EventArgs e)

{

FileDataSource source = new FileDataSource();

List<string> nameList = new List<string>() { "Files/Microsoft.jpg", "Files/MSDN.jpg", "Files/Site.css" };

CloudBlobClient client = account.CreateCloudBlobClient();

CloudBlobContainer container = client.GetContainerReference("container");

container.CreateIfNotExist();

var permission = container.GetPermissions();

permission.PublicAccess = BlobContainerPublicAccessType.Container;

container.SetPermissions(permission);

bool flag = false;

foreach (string name in nameList)

{

if (name.Substring(name.LastIndexOf('.') + 1).Equals("jpg") && File.Exists(Server.MapPath(name)))

{

if (!source.FileExists(name, "image"))

{

flag = true;

CloudBlob blob = container.GetBlobReference(name);

blob.UploadFile(Server.MapPath(name));

FileEntity entity = new FileEntity("image");

entity.FileName = name;

entity.FileUrl = blob.Uri.ToString();

source.AddFile(entity);

lbContent.Text += String.Format("The image file {0} is uploaded successes.
", name);

}

}

else if (name.Substring(name.LastIndexOf('.') + 1).Equals("css") && File.Exists(Server.MapPath(name)))

{

if (!source.FileExists(name, "css"))

{

flag = true;

CloudBlob blob = container.GetBlobReference(name);

blob.UploadFile(Server.MapPath(name));

FileEntity entity = new FileEntity("css");

entity.FileName = name;

entity.FileUrl = blob.Uri.ToString();

source.AddFile(entity);

lbContent.Text += String.Format("The css file {0} is uploaded successes.
", name);

}

}

}

if (!flag)

{

lbContent.Text = "You had uploaded these resources";

}

}

protected void LinkButton1_Click(object sender, EventArgs e)

{

Response.Redirect("Default.aspx");

}

}

public partial class FileUploadPage : System.Web.UI.Page

{

private static CloudStorageAccount account;

public List<FileEntity> files = new List<FileEntity>();

protected void Page_Load(object sender, EventArgs e)

{

account = CloudStorageAccount.FromConfigurationSetting("StorageConnections");

}

/// <summary>

/// Upload existing resources. ("Files" folder)

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

protected void btnUpload_Click(object sender, EventArgs e)

{

FileDataSource source = new FileDataSource();

List<string> nameList = new List<string>() { "Files/Microsoft.jpg", "Files/MSDN.jpg", "Files/Site.css" };

CloudBlobClient client = account.CreateCloudBlobClient();

CloudBlobContainer container = client.GetContainerReference("container");

container.CreateIfNotExist();

var permission = container.GetPermissions();

permission.PublicAccess = BlobContainerPublicAccessType.Container;

container.SetPermissions(permission);

bool flag = false;

foreach (string name in nameList)

{

if (name.Substring(name.LastIndexOf('.') + 1).Equals("jpg") && File.Exists(Server.MapPath(name)))

{

if (!source.FileExists(name, "image"))

{

flag = true;

CloudBlob blob = container.GetBlobReference(name);

blob.UploadFile(Server.MapPath(name));

FileEntity entity = new FileEntity("image");

entity.FileName = name;

entity.FileUrl = blob.Uri.ToString();

source.AddFile(entity);

lbContent.Text += String.Format("The image file {0} is uploaded successes.
", name);

}

}

else if (name.Substring(name.LastIndexOf('.') + 1).Equals("css") && File.Exists(Server.MapPath(name)))

{

if (!source.FileExists(name, "css"))

{

flag = true;

CloudBlob blob = container.GetBlobReference(name);

blob.UploadFile(Server.MapPath(name));

FileEntity entity = new FileEntity("css");

entity.FileName = name;

entity.FileUrl = blob.Uri.ToString();

source.AddFile(entity);

lbContent.Text += String.Format("The css file {0} is uploaded successes.
", name);

}

}

}

if (!flag)

{

lbContent.Text = "You had uploaded these resources";

}

}

protected void LinkButton1_Click(object sender, EventArgs e)

{

Response.Redirect("Default.aspx");

}

}

Step 5. Please add your Windows Azure Storage account name and key in the Azure project. If you do not have one, use Windows Azure Storage Emulator for testing.

Step 6. Build the application and you can debug it.

源码下载

一个使用微软Azure blob实现文件下载功能的实例-附带源文件的更多相关文章

  1. presto访问 Azure blob storage

    当集群使用Azure Blog Storage时,prestoDB无法获取返回结果,在此记录下 如下,hive里面的两个表,一个使用的是本地的hdfs,一个是使用 azure blob storage ...

  2. 微软Azure云主机及blob存储的网络性能测试

    http://www.cnblogs.com/sennly/p/4137024.html 微软Azure云主机及blob存储的网络性能测试 1. 测试目的 本次测试的目的在于对微软Azure的云主机. ...

  3. 阿里云ONS而微软Azure Service Bus体系结构和功能比较

    阿里云ONS而微软Azure Service bus体系结构和功能比较 版权所有所有,转载请注明出处http://blog.csdn.net/yangzhenping.谢谢! 阿里云的开放消息服务: ...

  4. 微软开放技术发布开源 Jenkins 插件以将 Windows Azure Blob 服务用的开作存储库

     发布于 2014-02-10 作者 陈 忠岳 持续集成 (CI) 的历史源远流长, 其宗旨在于软件团队在敏捷环境中不断将他们的工作整合为持续构建.管理 CI 进程的工具已存在一段时间.过去几年中 ...

  5. 使用 Azure Blob Stoage 实现一个静态文件服务器

    什么是Azure Blob Stoage Azure Blob Stoage 是微软Azure的对象存储服务.国内的云一般叫OSS,是一种用来存储非结构化数据的服务,比如音频,视频,图片,文本等等.用 ...

  6. 微软Azure配置中心 App Configuration (二):Feature Flag 功能开关特性

    写在前面 Web服务开发过程中我们经常有这样的需求: 某些功能我必须我修改了配置才启用,比如新用户注册送券等: 某个功能需到特定的时间才启用,过后就失效,比如春节活动等: 某些功能,我想先对10%的用 ...

  7. 【Azure 机器人】微软Azure Bot 编辑器系列(3) : 机器人对话流中加入帮助和取消按钮功能 (The Bot Framework Composer tutorials)

    欢迎来到微软机器人编辑器使用教程,从这里开始,创建一个简单的机器人. 在该系列文章中,每一篇都将通过添加更多的功能来构建机器人.当完成教程中的全部内容后,你将成功的创建一个天气机器人(Weather ...

  8. 欢迎阅读daxnet的新博客:一个基于Microsoft Azure、ASP.NET Core和Docker的博客系统

    2008年11月,我在博客园开通了个人帐号,并在博客园发表了自己的第一篇博客.当然,我写博客也不是从2008年才开始的,在更早时候,也在CSDN和系统分析员协会(之后名为"希赛网" ...

  9. 一个基于Microsoft Azure、ASP.NET Core和Docker的博客系统

    2008年11月,我在博客园开通了个人帐号,并在博客园发表了自己的第一篇博客.当然,我写博客也不是从2008年才开始的,在更早时候,也在CSDN和系统分析员协会(之后名为“希赛网”)个人空间发布过一些 ...

随机推荐

  1. Delphi 7事件的多处理机制

    Delphi 7事件的多处理机制Allen Tao2007-08-19 首先解释一下这个题目.在我使用Delphi 7的过程中发现,一个对象的事件只能被一个过程处理.如果多次给这个对象的事件赋给处理事 ...

  2. Android:改变Activity切换方式

    overridePendingTransition(enterAnim, exitAnim); Intent intent =new Intent(this,item2.class); startAc ...

  3. ADO.NET基础01(ADO.NET组成,数据库的方式,SqlCommand,SqlDataReader)

    什么是ADO.NET: ADO.NET就是一组类库,这组类库可以让我们通过程序的方式访问数据库,就像System.IO下的类操作文件一样, System.Data.这组类是用来操作数据库(不光是MSS ...

  4. (转)SSI开发环境搭建

    本文转自:http://blog.csdn.net/lifuxiangcaohui/article/details/7187869 先来点文字性的描述: MVC对于我们来说,已经不陌生了,它起源于20 ...

  5. Tomcat启动报错:严重: StandardServer.await: create[8005] java.net.BindException: Cannot assign requested address

    org.apache.catalina.core.StandardServer await        SEVERE: StandardServer.await: create[8005]:    ...

  6. 确认某端口占用情况并结束相应进程(Windows)

    (1)确认某端口是否被占用 (2)通过查找对应的PID号,定位是哪一个进程在使用该端口 (3)通过PID号结束该进程 # 查找端口2000是否被占用C:\Users\tdcqma>netstat ...

  7. POJ 3185 The Water Bowls(高斯消元-枚举变元个数)

    题目链接:http://poj.org/problem?id=3185 题意:20盏灯排成一排.操作第i盏灯的时候,i-1和i+1盏灯的状态均会改变.给定初始状态,问最少操作多少盏灯使得所有灯的状态最 ...

  8. Android移动应用开发中常见的经验技巧总结

    转:http://wwwdevstorecn/essay/essayInfo/6128.html 1. 对话保持的解决方案. 要求: 1.app中使用webview访问具体网站的内容,但是app与服务 ...

  9. Hbase总结(一)-hbase命令,hbase安装,与Hive的区别,与传统数据库的区别,Hbase数据模型

    Hbase总结(一)-hbase命令 下面我们看看HBase Shell的一些基本操作命令,我列出了几个常用的HBase Shell命令,如下: 名称 命令表达式 创建表 create '表名称', ...

  10. maximum-gap(经过了提示)

    下面的分桶个数做的不太好,原来的解法是用的 int gap = (big - small) / vlen; if (gap == 0) { gap = 1; } 下面是现在的Java解法: packa ...