深入探索Azure存储:从客户端构建到Blob应用
1. 构建存储客户端的挑战与解决方案
在为新的语言或平台实现存储客户端库时,可能会遇到一些阻碍。部分主流语言不支持SHA - 256(不过HMAC部分实现起来较为简单)。例如,若要实现该库的Erlang版本,就需要自行研究SHA - 256和HMAC的实现方式(可参考http://github.com/sriramk/winazureerl/ )。虽然研究和调试加密算法是件麻烦事,但它能提升请求的安全性。
生成签名头部后,服务器端的Windows Azure存储服务会执行相同流程生成签名,并检查客户端生成的签名是否匹配。若不匹配,会返回403错误。编写存储客户端时调试这类错误可能很痛苦,因为可能出现多种问题。调试时,可参考可靠的存储客户端实现,对比每一步的中间值。
2. 创建与上传操作
有了用于上传的容器后,上传Blob就很简单,只需向正确的URL发送HTTP PUT请求,并在请求中包含要上传的数据。以下是示例代码:
public bool CreateBlob(string containerName, string blobName,
byte[] data, string contentType)
{
HttpWebResponse response = DoStorageRequest(
containerName + "/" + blobName,
超级会员免费看
订阅专栏 解锁全文
17

被折叠的 条评论
为什么被折叠?



