1. public class Album : TableServiceEntity
  2. {
  3. }
  4. public class PhotoAlbumDataContext : TableServiceContext
  5. {
  6. public PhotoAlbumDataContext()
  7. : this(CloudStorageAccount.FromConfigurationSetting("DataConnectionString"))
  8. {
  9. }
  10.  
  11. public PhotoAlbumDataContext(Microsoft.WindowsAzure.CloudStorageAccount account)
  12. : base(account.TableEndpoint.ToString(), account.Credentials)
  13. {
  14. if (!initialized)
  15. {
  16. lock (initializationLock)
  17. {
  18. if (!initialized)
  19. {
  20. this.CreateTables();
  21. initialized = true;
  22. }
  23. }
  24. }
  25.  
  26. }
  27. //getlist
  28. var context = new PhotoAlbumDataContext();
  29. var list=context.Albums.AsTableServiceQuery().AsEnumerable()
  30.  
  31. //add
  32. context.AddObject("Alblum_TableName", new Album());
  33. //context.SaveChanges();
  34. context.SaveChanges(SaveChangesOptions.ContinueOnError);
  35.  
  36. //get delete
  37. var album = context.Albums
  38. .Where(a => a.AlbumId == albumName && a.PartitionKey == owner.ToLowerInvariant()).AsTableServiceQuery()
  39. .Single();
  40.  
  41. context.DeleteObject(album);
  42. context.SaveChanges();
  43.  
  44. //delete
  45. context.AttachTo("TableName", photoRow, "*");
  46. context.DeleteObject(photoRow);
  47. context.SaveChanges();
  48.  
  49. //update
  50. var albumRow = new Album(album);
  51. // attach and update the photo row
  52. context.AttachTo("TableName", albumRow, "*");
  53. context.UpdateObject(albumRow);
  54. context.SaveChanges();

Table Service

  1. public class Subscriber : TableEntity
  2. {
  3. [Required]
  4. [Display(Name = "List Name")]
  5. public string ListName
  6. {
  7. get
  8. {
  9. return this.PartitionKey; //分区键
  10. }
  11. set
  12. {
  13. this.PartitionKey = value;
  14. }
  15. }
  16.  
  17. [Required]
  18. [Display(Name = "Email Address")]
  19. public string EmailAddress
  20. {
  21. get
  22. {
  23. return this.RowKey;
  24. }
  25. set
  26. {
  27. this.RowKey = value;
  28. }
  29. }
  30.  
  31. public string SubscriberGUID { get; set; }
  32.  
  33. public bool? Verified { get; set; }
  34. }
  35. }
  36.  
  37. var storageAccount = CloudStorageAccount.Parse(ConfigurationManager.ConnectionStrings["StorageConnectionString"].ConnectionString);
  38. var tableClient = storageAccount.CreateCloudTableClient();
  39. var mailingListTable = tableClient.GetTableReference("mailinglist");
  40. mailingListTable.CreateIfNotExists();
  41.  
  42. //获取Get
  43. var retrieveOperation = TableOperation.Retrieve<T>(_partitionKey, _rowKey);
  44. var retrievedResult = mailingListTable.Execute(retrieveOperation);
  45. return retrievedResult.Result as T;
  46.  
  47. //GetList
  48. string filter = TableQuery.CombineFilters(
  49. TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, _partitionKey),
  50. TableOperators.And,
  51. TableQuery.GenerateFilterCondition("SubscriberGUID", QueryComparisons.Equal, subscriberGUID));
  52. var query = new TableQuery<Subscriber>().Where(filter);
  53. var subscribers = mailingListTable.ExecuteQuery(query).ToList();
  54.  
  55. //添加 Add
  56. var insertOperation = TableOperation.Insert(newSubscriber);
  57. mailingListTable.Execute(insertOperation);
  58.  
  59. //Update Or Insert
  60. var upsertOperation = TableOperation.InsertOrReplace(emailRowInTable);
  61. mailingListTable.Execute(upsertOperation);
  62.  
  63. //Update
  64. replaceOperation = TableOperation.Replace(emailRowInTable);
  65. mailingListTable.Execute(replaceOperation);
  66.  
  67. //Delete
  68. var deleteOperation = TableOperation.Delete(emailRowToDelete);
  69. mailingListTable.Execute(deleteOperation);

Sotrage.Tables

  1. var storageAccount = CloudStorageAccount.Parse(ConfigurationManager.ConnectionStrings["StorageConnectionString"].ConnectionString);
  2. var queueClient = storageAccount.CreateCloudQueueClient();
  3. foreach(var q in queueClient.ListQueues()){//所有队列
  4. var msg = q.GetMessage();
  5. var id = msg.Id;
  6. var name=q.Name; //队列名字:azuremailsubscribequeue
  7. }
  8.  
  9. subscribeQueue = queueClient.GetQueueReference("azuremailsubscribequeue");
  10. subscribeQueue.CreateIfNotExists();
  11.  
  12. subscribeQueue.AddMessage(new CloudQueueMessage(newSubscriber.SubscriberGUID + "," + newSubscriber.ListName));
  13.  
  14. msg = subscribeQueue.GetMessage();
  15.  
  16. subscribeQueue.DeleteMessage(msg);
  17.  
  18. public class WorkerRole : RoleEntryPoint
  19. {
  20.  
  21. }

CloudQueue

  1. using System.Net;
  2. using System.Net.Mail;
  3. using Microsoft.WindowsAzure.Diagnostics;
  4. using Microsoft.WindowsAzure.ServiceRuntime;
  5. using Microsoft.WindowsAzure.Storage.Blob;
  6. using Microsoft.WindowsAzure.Storage.Queue;
  7. using Microsoft.WindowsAzure.Storage.Table;
  8. using SendGridMail;
  9. using SendGridMail.Transport;
  10.  
  11. var storageAccount=CloudStorageAccount.FromConfigurationSetting("DataConnectionString");
  12.  
  13. private static void SendSubscribeEmail(string subscriberGUID, Subscriber subscriber, MailingList mailingList)
  14. {
  15. var email = SendGrid.GenerateInstance();
  16. email.From = new MailAddress(mailingList.FromEmailAddress);
  17. email.AddTo(subscriber.EmailAddress);
  18. string subscribeURL = RoleEnvironment.GetConfigurationSettingValue("AzureMailServiceURL") +
  19. "/subscribe?id=" + subscriberGUID + "&listName=" + subscriber.ListName;
  20. email.Html = String.Format("<p>Click the link below to subscribe to {0}. " +
  21. "If you don't confirm your subscription, you won't be subscribed to the list.</p>" +
  22. "<a href=\"{1}\">Confirm Subscription</a>", mailingList.Description, subscribeURL);
  23. email.Text = String.Format("Copy and paste the following URL into your browser in order to subscribe to {0}. " +
  24. "If you don't confirm your subscription, you won't be subscribed to the list.\n" +
  25. "{1}", mailingList.Description, subscribeURL);
  26. email.Subject = "Subscribe to " + mailingList.Description;
  27. var credentials = new NetworkCredential(RoleEnvironment.GetConfigurationSettingValue("SendGridUserName"), RoleEnvironment.GetConfigurationSettingValue("SendGridPassword"));
  28. var transportREST = REST.GetInstance(credentials);
  29. transportREST.Deliver(email);
  30. }
  31.  
  32. private string GetBlobText(string blogRef)
  33. {
  34. var blob = blobContainer.GetBlockBlobReference(blogRef);
  35. blob.FetchAttributes();
  36. var blobSize = blob.Properties.Length;
  37. using (var memoryStream = new MemoryStream((int)blobSize))
  38. {
  39. blob.DownloadToStream(memoryStream);
  40. return System.Text.Encoding.UTF8.GetString(memoryStream.ToArray());
  41. }
  42. }
  43.  
  44. //upload image (stream)
  45. var blob = container.GetBlobReference(file);
  46. blob.Properties.ContentType = mimeType;
  47. blob.UploadFromStream(binary);
  48.  
  49. //down image
  50. var client = this.storageAccount.CreateCloudBlobClient();
  51. var container = client.GetContainerReference(owner);
  52.  
  53. using (var ms = new MemoryStream())
  54. {
  55. container.GetBlobReference(file).DownloadToStream(ms);
  56. var image = Image.FromStream(ms);
  57. }
  58.  
  59. // save it off to blob storage
  60. using (var thumbStream = new MemoryStream())
  61. {
  62. thumb.Save(
  63. thumbStream,
  64. System.Drawing.Imaging.ImageFormat.Jpeg);
  65.  
  66. thumbStream.Position = ; // reset;
  67.  
  68. var thumbBlob = container.GetBlobReference(Path.Combine("thumb", file));
  69. thumbBlob.Properties.ContentType = "image/jpeg";
  70. thumbBlob.UploadFromStream(thumbStream);
  71. }
  72.  
  73. //use image
  74. var blobUri = client.GetContainerReference(owner).GetBlobReference(file).Uri.ToString();
  75. var thumbUri = client.GetContainerReference(owner).GetBlobReference(Path.Combine("thumb", file)).Uri.ToString();
  76.  
  77. //delete
  78.  
  79. var blobGone = container.GetBlobReference(filename).DeleteIfExists();
  80. var thumbGone = container.GetBlobReference(thumbname).DeleteIfExists();

Storage.Blob

windows azure 实例的更多相关文章

  1. Windows Azure 名词定义(Glossary)

    Glossary(名词) Definition(定义) Availability Set 可用性组 refers to two or more Virtual Machines deployed ac ...

  2. CSV 客座文章系列: Pruffi 通过 Windows Azure 挖掘社交媒体的强大招聘潜能

    编辑人员注释:今天这篇文章由 Pruffi 创始人 Alena Vladimirskaya 和 Pruffi 的 CTO Alexander Ivanov 联合撰写,介绍了该公司如何使用 Window ...

  3. CSV 客座文章系列:KGroup 通过 Windows Azure 将 Qoob 内容管理发布到云中

    编辑人员注释: 今天这篇文章由 KGroup 首席软件架构师兼研发部主管 Jody Donetti 与 KGroup 技术总监 Simone Procopio 共同撰写,介绍了 KGroup 如何使用 ...

  4. Windows Azure Virtual Machine (28) 使用Azure实例级别IP,Instance-Level Public IP Address (PIP)

    <Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China 熟悉Azure平台的读者都知道,我们在使用Azure Virtual ...

  5. Windows Azure虚拟机和云服务实例计费方式更新

    在之前的Windows Azure计费账单中,A0,A1,A2,A3,A4系列的虚拟机(云服务实例)都是以A1为基准计费单位的,即: 虚拟机大小 计费单位(小时) A0 A1*0.25 A1 A1*1 ...

  6. 宣布在 Azure 镜像库中正式推出 Windows Server 2012 R2 并降低 Windows Azure 的实例定价

    我们今天将宣布两条消息,为使用基础结构服务的客户提供更多选择和成本节约:在镜像库中推出 Windows Server 2012 R2 以及降低 Memory Intensive 计算实例定价. 虚拟机 ...

  7. 禁用 Windows Azure 网站中的 ARR 实例关联

    编辑人员注释: 本博客文章由 Windows Azure 网站团队的项目经理 Erez Benari 撰写. 在 Windows Azure 网站中设置网站的多个实例是横向扩展网站的绝佳方式,Azur ...

  8. 简化 Web 应用程序与 Windows Azure Active Directory、ASP.NET 和 Visual Studio 的集成

    大家好! 今天的博文深入讨论我们今天推出的开发人员工具和框架中的一些新功能.我们通过与 ASP.NET 和 Visual Studio 团队合作开发了一些重大的增强功能,让开发人员能够轻松使用 Win ...

  9. 今天Windows Azure Live to Code的分享

    今天参加了微软广州的Live to Code,晚上回公司OT写了封报告E-mail,也没让公司今天白出工资给我... 因为没有涉及到公司机密什么的,所以就拿出来跟大家分享一下. 首先要说明的是,在会议 ...

随机推荐

  1. 2013 南京邀请赛 A play the dice 求概率

    /** 大意:给定一个色子,有n个面,每一个面上有一个数字,在其中的m个面上有特殊的颜色,当掷出的色子出现这m个颜色之一时,可以再掷一次..求其最后的期望 思路:假设 期望为ans 4 ans = 1 ...

  2. Multiple markers at this line @Override的解决方法

    Multiple markers at this line - implements java.awt.event.ActionListener.actionPerformed - The metho ...

  3. TPM 2.0 近况及模拟器开发

    可信计算平台模块TPM 2.0的相关标准和技术准则由 TCG ( Trust Computing Group )于2011年前后提出,至今已经过了多次修改.该标准无疑将成为下一代可信计算平台模块的业界 ...

  4. Windows Azure 网站上的 WebSocket 简介

    编辑人员注释:本文章由 Windows Azure 网站团队的首席项目经理 Stefan Schackow 撰写. Windows Azure 网站最近新增了对 WebSocket 协议的支持..NE ...

  5. c# datagridviewcomboboxcell值无效的解决办法

    一直认为是数据库存储的数据和datagridviewcomboboxcell对不上导致,今天碰到两者对应上了,预览的时候还是提示错误, 查看了下网上其他大神的解决方法,是数据库字段类型有误,查看了下, ...

  6. 【Eclipse】离线插件安装

    1.在eclipse里根目录里,dropins里建一个目录,名字叫sonar(这个名字随便),再在svn下面建一个目录eclipse.在根目录里建一个目录links目录,并建一个sonar.link文 ...

  7. Java Pattern Matcher 正则应用

    转自:http://www.itzhai.com/java-notes-regex-matches-and-lookingat.html#read-more 1.基本语法 2.String内建的正则表 ...

  8. django cookie

    设置:auth.login(request, user)                response = HttpResponseRedirect(reverse("index" ...

  9. QT窗口置顶/真透明/背景模糊/非矩形/跳过任务栏分页器/无边框/无焦点点击/焦点穿透

    qt 窗口置顶/真透明/背景模糊/非矩形/跳过任务栏分页器/无边框/无焦点点击/焦点穿透 窗口置顶qt 里是 setWindowFlags(Qt::WindowStaysOnTopHint)kde 里 ...

  10. BNU 26579 Andrew the Ant 【蚂蚁】

    链接: http://www.bnuoj.com/bnuoj/problem_show.php?pid=26579 http://www.bnuoj.com/bnuoj/contest_show.ph ...