将图片上载到Windows Azure网站

JQu*_*ile 12 asp.net-mvc azure

我有一个ASP.NET MVC 4应用程序,我想部署到Windows Azure.此应用的一部分涉及上传图片.上传图片时,我想将图片存储在位于的目录中/pictures/uploaded.

我的问题是,如何将图片上传到我在Windows Azure上托管的应用程序中的相对路径?到目前为止,我的应用程序已托管在虚拟机中.我能够通过使用以下内容来完成上述操作:

string path = ConfigurationManager.AppSettings["rootWebDirectory"] + "/pictures/uploaded;

// Get the file path
if (Directory.Exists(path) == false)
  Directory.CreateDirectory(path);

string filePath = path + "/uploaded" + DateTime.UtcNow.Milliseconds + ".png";
filePath = filePath.Replace("/", "\\").Replace("\\\\", "\\");

// Write the picture to the file system
byte[] bytes = GetPictureBytes();
using (FileStream fileStream = new FileStream(filePath, FileMode.Create))
{
  fileStream.Write(bytes, 0, bytes.Length);
  fileStream.Flush();
  fileStream.Close();
}
Run Code Online (Sandbox Code Playgroud)

目前,ConfigurationManager.AppSettings["rootWebDirectory"]指向绝对路径.我相信这是我的问题所在.我无法弄清楚如何将所有这些切换到相对路径.

谢谢!

Mag*_*son 20

这是我的简单描述如何在天蓝色中设置它. http://geekswithblogs.net/MagnusKarlsson/archive/2012/12/02/how-to-use-azure-storage-for-images.aspx

//编辑; 继承了我博客的完整示例(如果博客死了).yourViewName.cshtml

 @model List<string>  
 @{
     ViewBag.Title = "Index";
 }

 <h2>Index</h2>
 <form action="@Url.Action("Upload")" method="post" enctype="multipart/form-data">

     <label for="file">Filename:</label>
     <input type="file" name="file" id="file1" />
     <br />
     <label for="file">Filename:</label>
     <input type="file" name="file" id="file2" />
     <br />
     <label for="file">Filename:</label>
     <input type="file" name="file" id="file3" />
     <br />
     <label for="file">Filename:</label>
     <input type="file" name="file" id="file4" />
     <br />
     <input type="submit" value="Submit" />

 </form>

 @foreach (var item in Model) {

     <img src="@item" alt="Alternate text"/>
  }
Run Code Online (Sandbox Code Playgroud)

你的控制器动作

public ActionResult Upload(IEnumerable<HttpPostedFileBase> file)
         {
             BlobHandler bh = new BlobHandler("containername");
             bh.Upload(file);
             var blobUris=bh.GetBlobs();

             return RedirectToAction("Index",blobUris);
         }
Run Code Online (Sandbox Code Playgroud)

你的模特

 public class BlobHandler
     {
         // Retrieve storage account from connection string.
         CloudStorageAccount storageAccount = CloudStorageAccount.Parse(
         CloudConfigurationManager.GetSetting("StorageConnectionString"));

         private string imageDirecoryUrl; 

         /// <summary>
         /// Receives the users Id for where the pictures are and creates 
         /// a blob storage with that name if it does not exist.
         /// </summary>
         /// <param name="imageDirecoryUrl"></param>
         public BlobHandler(string imageDirecoryUrl)
         {
             this.imageDirecoryUrl = imageDirecoryUrl;
             // Create the blob client.
             CloudBlobClient blobClient = storageAccount.CreateCloudBlobClient();

             // Retrieve a reference to a container. 
             CloudBlobContainer container = blobClient.GetContainerReference(imageDirecoryUrl);

             // Create the container if it doesn't already exist.
             container.CreateIfNotExists();

             //Make available to everyone
             container.SetPermissions(
                 new BlobContainerPermissions
                 {
                     PublicAccess = BlobContainerPublicAccessType.Blob
                 });
         }

         public void Upload(IEnumerable<HttpPostedFileBase> file)
         {
             // Create the blob client.
             CloudBlobClient blobClient = storageAccount.CreateCloudBlobClient();

             // Retrieve a reference to a container. 
             CloudBlobContainer container = blobClient.GetContainerReference(imageDirecoryUrl);

             if (file != null)
             {
                 foreach (var f in file)
                 {
                     if (f != null)
                     {
                         CloudBlockBlob blockBlob = container.GetBlockBlobReference(f.FileName);
                         blockBlob.UploadFromStream(f.InputStream);
                     }
                 }
             }
         }

         public List<string> GetBlobs()
         {
             // Create the blob client. 
             CloudBlobClient blobClient = storageAccount.CreateCloudBlobClient();

             // Retrieve reference to a previously created container.
             CloudBlobContainer container = blobClient.GetContainerReference(imageDirecoryUrl);

             List<string> blobs = new List<string>();

             // Loop over blobs within the container and output the URI to each of them
             foreach (var blobItem in container.ListBlobs())
                 blobs.Add(blobItem.Uri.ToString());

             return blobs;
         }
     }
Run Code Online (Sandbox Code Playgroud)

  • @SebastiánRojasR,不确定你要求的是一个疯狂的猜测是"如何使用本地开发进行blob存储?" https://azure.microsoft.com/en-us/documentation/articles/storage-use-emulator/启动Azure SDK中包含的Azure存储模拟器并运行web.config转换,将您的StorageConnectionstring中的值替换为value =" UseDevelopmentStorage =真" (2认同)

Mar*_*nce 10

数据和图像不应存储在网站目录中.这就是Azure Blob存储的原因.

Azure通过将网站复制到实例来工作,因此如果存在多个实例,则上传的图像(存储在本地实例中)将变得不同步,如果存在冲突,您甚至会丢失图像.

如果您真的想这样做,下面的行将为您提供您想要的:

string path = Server.MapPath("~/pictures/uploaded");
Run Code Online (Sandbox Code Playgroud)