Hands-On Lab
SharePoint 2010 & Azure: Blob Storage
Lab version: 1.0
Last updated:11/17/2018
Contents
Section 1: Smooth Streaming Video from Blob Storage
Overview
Exercise 1: Smooth Streaming Content
Task 1 – Installing the Expresion Encoder Publishing Plugin
Task 2 – Publishing the Content
Exercise 2: Smooth Streaming in SharePoint 2010
Task 1 – Playing the Video in SharePoint 2010
Task 2 – Creating a Time-Limited Uri
Summary
Section 2: SharePoint 2010 Video Library.
Overview
Exercise 1: Populating Blob Storage
Task 1 – Creating the Web Role Project
Task 2 – Creating the User Interface
Task 3 – Creating a Data Class
Task 4 – Initiating Azure Storage
Task 5 – Coding Project Functionality
Task 6 – Testing the Solution
Task 7 – Deploying the Web Role to Azure
Task 8 – Playing Videos in SharePoint 2010 Media Player
Exercise 2: Creating a Media Player
Task 1 – Creating the Intermediate REST Service
Task 2 – Creating the Silverlight Project
Task 3 – Coding the Silverlight Application
Task 4 – Deploying the Solution to SharePoint 2010
Summary
Section 1: Smooth Streaming Video from Blob Storage
Overview
In this lab, you will build a Silverlight Media Player that plays videos stored in Azure Blob Storage. The player will utilize “Smooth Streaming”, which is the Microsoft HTTP-based adaptive streaming protocol. This approach uses HTTP progressive download to download and play chunks of a video stream.
Objectives
In this lab, you will:
- Learn to create a Silverlight Media Player.
- Learn to store videos in Azure Blob Storage.
System Requirements
You must have the following items to complete this lab:
- Windows Azure SDK and Windows Azure Tools for Microsoft Visual Studio
- Access to a Windows Azure account
- Expression Blend
Setup
This lab uses several tools and resources that must be downloaded and installed prior to starting the lab. These resources are:
- The Big Buck Bunny video
- Adaptive Streaming with Windows Azure Blobs Uploader
- Azure Storage Explorer
Download the Big Buck Bunny video from and save it in a working directory.
Download the Adaptive Streaming with Windows Azure Blobs Uploader (AdaptiveStreamingAzure_binaries.zip). Unzip the files into the same working directory where you placed the Big Buck Bunny video.
Download the Azure Storage Explorer.Run AzureStorageExplorer4.msi to install the tool.
The Windows Azure SDK (included in Windows Azure Tools for Visual Studio) installs a simulation environment on your development machine for testing Azure applications locally before deploying them to the cloud. The simulation environment consists of the development fabric to host web and worker roles, and the development storage which simulates cloud blob, table and queue storage locally.
Development storage uses SQL Server as its underlying storage mechanism, and by default the SDK will attempt to configure it to use SQL Server Express. If you do not have SQL Server Express installed before installing the SDK, or you wish to simply use an existing SQL Server instance to host the development storage database, you must run the dsinit command to select the SQL Server instance where the database will be created.
Please see instructions below for how to run dsinit.
Using dsinit to Configure Development Storage
- Open a command prompt.
- Edit the following command line as appropriate for your environment, where [AzureSDKInstallDrive] is the drive where you installed the Azure SDK (or Windows Azure Tools for Visual Studio), and [YourSqlInstance] is the SqlServer where you want to create the development storage database.
[AzureSDKInstallDrive]\ Program Files\Windows Azure SDK\v1.3\bin\devstore\dsinit.exe /sqlinstance:[YourSqlInstance]
Example Command Line:
“C:\Program Files\Windows Azure SDK\v1.3\bin\devstore\dsinit.exe” /sqlinstance:. - Note that the sample command line above uses the value “.” for the sqlinstance argument, which specifies that the local default SQL instance will be used for development storage.
Exercises
This Hands-On Lab is comprised of the following exercises:
- Smooth Streaming Content
- Smooth Steaming in SharePoint 2010
Estimated Time to complete this lab: 30 minutes
Exercise 1: Smooth Streaming Content
In this exercise, you will create the smooth streaming content to upload into Azure. Then you will play the content in a SharePoint 2010 site.
Task 1 – Installing the Expresion Encoder Publishing Plugin
In this task,you will install the Expression Encoder Publishing Plugin for creating the smooth streaming content.
- Open a Command Prompt window running as administrator on your machine.
- Change the directory to the EncoderPlugin directory associated with the Adaptive Streaming with Windows Azure Blobs Uploader binaries you downloaded during the exercise setup.
- Execute install.cmd.
Task 2 – Publishing the Content
In this task, you will create the smooth streaming content and publish it to Azure.
- OpenMicrosoft Expression Encoder 4.
- In the Load a New Project screen, click Silverlight Project.
- In Expression Encoder 4, click Import.
- In the Import Media Files, navigate to the video you downloaded earlier and click Open.
- Right click the video and select Apply Preset>Encoding for Silverlight>IIS Smooth Streaming>VC-1 IIS Smooth Streaming - SD 480p VBR.
- In the Publish Window, select Windows Azure Adaptive Streaming Publisher from the Publish To drop-down list.
- Check the Publish After Encode box.
- Enter the Account Name for your Azure account.
- Enter the Account Key for your Azure account.
- In the Path field, enter smoothstreaming.
Figure 1
Publish Settings
- Select File>Save Job from the main menu and save the project with the name SmoothStreamingEncoding.
- Click Encode.
- After the encoding and uploading process is complete, the browser will open with the video running.
Exercise 2: Smooth Streaming in SharePoint 2010
In this exercise, you will play the smooth streaming content in a SharePoint 2010 site.
Task 1 – Playing the Video in SharePoint 2010
In this task, you will play the smooth streaming video in SharePoint 2010.
- Run the Azure Storage Explorer you installed as part of the lab set up.
- When prompted, add your account information.
- Click the Blobs button in the ribbon.
- Double click the smoothstreaming folder to display all of the files previously uploaded into Azure.
- Double click the MediaPlayerTemplate.xap file to open the Properties window.
- Record the Absolute Uri to the package for use in SharePoint 2010 later.
- Double click the Manifest file.
- Record the Absolute Uri to the Manifest for use in SharePoint 2010 later
- Open a SharePoint 2010 site and optionally add a new page for hosting web parts.
- Select Site Actions>Edit Page.
- Click Insert>Web Part in the ribbon.
- In the Media and Content category, select the Silverlight Web Part and click Add.
- In the Silverlight Web Part dialog, enter the absolute Uri to the MediaPlayerTemplate.xap file and click OK.
- Click Edit Web Part.
- Under the Other Settings category, click Custom Initialization Parameters.
- Put the following string in this field being careful to enter the absolute Uri for your manifest.
XML
playerSettings=<Playlist>
AutoLoad>false</AutoLoad
<AutoPlay>false</AutoPlay
DisplayTimeCode>false</DisplayTimeCode
EnableOffline>true</EnableOffline
EnablePopOut>true</EnablePopOut
EnableCaptions>true</EnableCaptions
EnableCachedComposition>true</EnableCachedComposition
StretchNonSquarePixelsNoStretch</StretchNonSquarePixels
StartMuted>false</StartMuted
StartWithPlaylistShowing>false</StartWithPlaylistShowing
<Items>
PlaylistItem
AudioCodecWmaProfessional</AudioCodec
<Description</Description>
FileSize>510330196</FileSize
IsAdaptiveStreaming>true</IsAdaptiveStreaming
MediaSourceTHE ABSOLUTE URI TO YOUR MANIFEST BLOB CONTAINER</MediaSource
ThumbSource</ThumbSource
<Title>big_buck_bunny_480p_stereo</Title>
<DRM>false</DRM>
<VideoCodec>VC1</VideoCodec>
FrameRate>24.0000384000614</FrameRate
<Width>852</Width>
<Height>480</Height>
AspectRatioWidth>16</AspectRatioWidth
AspectRatioHeight>9</AspectRatioHeight
</PlaylistItem
</Items>
</Playlist>
- Click OK and the video should begin to play.
Task 2 – Creating a Time-Limited Uri
In this task, you will create a tme-limited URL for the video so that it can be played for only a specified period of time..
- Run the Azure Storage Explorer you installed as part of the lab set up.
- Click the Blobs button in the ribbon.
- Click the smoothstreaming folder.
- Click the Manifest file.
- Click the Security button in the ribbon.
- In the Blob & Container Security dialog, click the Shared Access Policies tab.
- In the Policy Name field type Time Limited.
- Check the Read box.
- In the Start Time and Expiry Time boxes, enter a time range.
Figure 2
Shared Access Policies
- Click Save Policies.
- Close the Blob & Container Security dialog.
- Click the Security button in the ribbon.
- In the Blob & Container Security dialog, click the Shared Access Signatures tab.
- Make sure the Container Name is set to smoothstreaming and the Blob Name references the Manifest file.
- In the Policy drop-down list, select the Time Limited policy.
- Click Generate Signature.
Figure 3
Shared Access Signatures
- Click Copy to Clipboard.
- Click the Container Access tab.
- Change the Container Access Level to Private.
- Click Update Access Level.
- Click Close.
- Return to the page where the Silverlight Web Part is located and edit the web part properties.
- Under the Other Settings category, click Custom Initialization Parameters.
- Carefully replace the value of the MediaSource element with the value you copied from the Azure Storage Explorer.
- Escape all of the ampersands in the new MediaSource element with & or the resulting XML will be invalid.
- Save the changes and play the video.
Summary
In this lab you learned about smooth streaming video. You used community tools to convert a video and save it into Azure blob storage. You then used the available Silverlight web part in SharePoint 2010 to play the video.
Section 2:SharePoint 2010 Video Library.
Overview
In this lab, you will create a video library and media player for SharePoint 2010. The videos will be stored as blobs in Azure and played through a custom Silverlight application.
Objectives
In this lab, you will:
- Learn to manage and utilize blob storage in Azure
- Learn to access blobs storage through Silverlight
System Requirements
You must have the following items to complete this lab:
- Windows Azure SDK and Windows Azure Tools for Microsoft Visual Studio
- Access to a Windows Azure account
- Visual Studio 2010 Power Tools extension
- Silverlight SharePoint Web Parts extension
Setup
Download and install the Visual Studio 2010 SharePont Power Tools extension. This is an extension for Visual Studio 2010 that supports creating Sandboxed Visual Web Parts.
Download and install the Silverlight SharePoint Web parts.This is an extension for Visual Studio 2010 that supports creating Silverlight wbe parts.
The Windows Azure SDK (included in Windows Azure Tools for Visual Studio) installs a simulation environment on your development machine for testing Azure applications locally before deploying them to the cloud. The simulation environment consists of the development fabric to host web and worker roles, and the development storage which simulates cloud blob, table and queue storage locally.
Development storage uses SQL Server as its underlying storage mechanism, and by default the SDK will attempt to configure it to use SQL Server Express. If you do not have SQL Server Express installed before installing the SDK, or you wish to simply use an existing SQL Server instance to host the development storage database, you must run the dsinit command to select the SQL Server instance where the database will be created.
Please see instructions below for how to run dsinit.
Using dsinit to Configure Development Storage
- Open a command prompt.
- Edit the following command line as appropriate for your environment, where [AzureSDKInstallDrive] is the drive where you installed the Azure SDK (or Windows Azure Tools for Visual Studio), and [YourSqlInstance] is the SqlServer where you want to create the development storage database.
[AzureSDKInstallDrive]\ Program Files\Windows Azure SDK\v1.3\bin\devstore\dsinit.exe /sqlinstance:[YourSqlInstance]
Example Command Line:
“C:\Program Files\Windows Azure SDK\v1.3\bin\devstore\dsinit.exe” /sqlinstance:. - Note that the sample command line above uses the value “.” for the sqlinstance argument, which specifies that the local default SQL instance will be used for development storage.
Exercises
This Hands-On Lab is comprised of the following exercises:
- Populating Blob Storage
- Creating a Media Player
Estimated Time to complete this lab: 60 minutes
Exercise 1: Populating Blob Storage
In this exercise, you will create a web role project to populate blob storage with videos.
Task 1 – Creating the Web Role Project
In this task, you will create a new web role project.
- Start Visual Studio 2010.
- Select File>New Project from the main menu.
- In the New Project dialog, select Visual C#>Cloud>Windows Azure Project.
- Name the new project AzureVideoManager and click OK.
- In the New Windows Azure Project dialog, select ASP.NET Web Role.
- Use the arrows to add the new web role to the solution.
- Hover over the web role project and click the pencil icon.
- Rename the web role VideoBlobManager and click OK.
Task 2 – Creating the User Interface
In this task, you will create the user interface for the web role.
- In the Solution Explorer, open Default.aspx for editing in Source view.
- Replace the markup in the page with the following code.
ASPX
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs"
Inherits="VideoBlobManager._Default" %>
<html xmlns="
<head runat="server">
<title>Video Blob Manager</title>
</head>
body
<form id="form1" runat="server">
<table
<tr
<td<strong>My Videos</strong</td>
<tdnbsp;</td>
</tr
<tr
<td<strong>Submit</strong</td>
<td>Click Browse, provide a name and select a category</td>
</tr
<tr
<td
<asp:Label ID="filePathLabel" Text="Video Path:"
AssociatedControlID="videoUploadControl" runat="server"
Style="font-family: Calibri; color: #000066;" />
</td>
<td
<asp:FileUpload ID="videoUploadControl" runat="server"
Style="font-family: Calibri" />
</td>
</tr
<tr
<td
<asp:Label ID="videoNameLabel" Text="Video Name:"
AssociatedControlID="videoNameBox" runat="server"
Style="font-family: Calibri; color: #000066;" />
</td>
<td
<asp:TextBox ID="videoNameBox" runat="server" Width="220px" />
</td>
</tr
<tr
<td
<asp:Label ID="categoryLabel" Text="Category:"
AssociatedControlID="dropdwnCategory" runat="server"
Style="font-family: Calibri; color: #000066;" />
</td>
<td
<asp:DropDownList ID="dropdwnCategory" runat="server"
Width="220px">
<asp:ListItem>Technical</asp:ListItem
<asp:ListItem>Marketing</asp:ListItem
<asp:ListItem>Business</asp:ListItem
<asp:ListItem>Sales</asp:ListItem
<asp:ListItem>Travel</asp:ListItem
<asp:ListItem>Personal</asp:ListItem
</asp:DropDownList
</td>
</tr
<tr
<td
</td>
<td
<asp:LinkButton ID="lnkbtnSubmitVideo" runat="server"
Font-Names="Calibri" OnClick="SubmitVideo_Click">
Submit Video</asp:LinkButton
|
<asp:LinkButton ID="lnkbtnClearFields" runat="server"
Font-Names="Calibri" OnClick="ClearFields_Click">
Clear Fields</asp:LinkButton
</td>
</tr
<tr
<td
<strong>View & Delete</strong>
</td>
<td
Click Delete to delete a specific video
</td>
</tr
<tr
<td
<asp:Label ID="lblDataGrd" runat="server" Text="Video List:"
Style="color: #000066;font-family: Calibri"</asp:Label
</td>
<td
<asp:GridView ID="videoList" AutoGenerateColumns="false"
DataKeyNames="FileUri" runat="server"
OnRowCommand="RowCommandHandler" Font-Names="Calibri"
Font-Size="Small" Width="296px">
<AlternatingRowStyleBackColor="#99CCFF"
Font-Names="Calibri" Font-Size="Small" />
<Columns>
<asp:ButtonFieldHeaderText="Delete"
Text="Delete" CommandName="DeleteVideo" />
<asp:HyperLinkFieldHeaderText="Link & Title"
DataTextField="VideoName"
DataNavigateUrlFields="FileUri" />
<asp:BoundFieldDataField="Category"
HeaderText="Category" />
<asp:BoundFieldDataField="DateSubmitted"
HeaderText="Date Submitted" />
</Columns>
<HeaderStyleBackColor="#000099" Font-Bold="True"
ForeColor="White" />
</asp:GridView
</td>
</tr
</table>
</form>
</body>
</html>
Figure 4
User Interface for Video Manager
Task 3 – Creating a Data Class
In this task, you will create a data class for managing video information.
- In the Solution Explorer, right click the VideoBlobManager project and select Add>Class from the context menu.
- In the Add New Item dialog, name the new class VideoBlobStorage.cs and click Add.
- Addthe following code inside the class definition.
C#
public Uri FileUri { get; set; }
public string VideoName { get; set; }
public string Category { get; set; }
public string DateSubmitted { get; set; }
Task 4 – Initiating Azure Storage
In this task, you will create a Global.asax file for initiating Azure Storage.
- In the Solution Explorer, right click the VideoBlobManager project and select Add>New Item from the context menu.
- In the Add New Item dialog, select Visual C#>Web>Global Application Class and click Add.
- At the top of the Global.asax file, add the following code references.
C#