我正在尝试通过 web-api 将文件从本地命令行客户端上传到 Azure 存储。为此,我正在使用 Azure 网站。与客户合作不是问题。而且我在本地一切正常。这是网络API代码:
public async Task<HttpResponseMessage> PostUpload()
{
// need a local resource to store uploaded files temporarily
LocalResource localResource = null;
try
{
// Azure web-site fails here
localResource = RoleEnvironment.GetLocalResource("TempStorage");
}
catch (Exception e)
{
return Request.CreateErrorResponse(HttpStatusCode.InternalServerError, "Unable to get access to local resources");
}
var provider = new MultipartFormDataStreamProvider(localResource.RootPath);
// Read the form data.
await Request.Content.ReadAsMultipartAsync(provider);
// snipped validation code
var container = // code to get container
foreach (var fileData in provider.FileData)
{
var filename = GetBlobName(fileData);
var blob = container.GetBlockBlobReference(filename);
using (var filestream = File.OpenRead(fileData.LocalFileName))
{
blob.UploadFromStream(filestream);
}
File.Delete(fileData.LocalFileName);
}
return Request.CreateResponse(HttpStatusCode.OK);
}
当我在本地运行时一切正常,但是一旦我在 Azure 中部署网站,我就无法上传,因为 Azure 网站无权访问 LocalResource。我需要切换到 Azure Web-Role。我可以切换,但访问本地文件系统让我很困扰。
MultipartFormDataStreamProvider() 的实例需要 LocalResource。而且我还没有找到将文件上传到 WebApi 的替代方法。我的计划是通过直接上传到 Azure 进行引导,而不在本地硬盘上存储任何内容。
有没有其他上传文件的方法?
ps 我已经看到共享访问签名的用法,我可以为客户端应用程序提供一个带有签名的 url,并让客户端直接上传到 Azure 博客。但我不确定这将是多么安全,并且(还)不太舒服将签名传递给客户端。目前我认为客户端将在非常恶劣的环境中运行,并且从客户端返回的任何内容都不可信。
UPD我的最终解决方案涉及使用在服务器上发布并传递给客户端的只写共享访问签名。然后客户端将文件直接上传到 Azure。这样我就省去了管理上传文件的很多麻烦。这里是我的解决方案的更详细描述。