In this lab, you will create a cloud development environment and build a cloud-hosted app.
In this exercise you obtain trial subscriptions to Office 365 and Azure. If you already have these subscriptions, you can skip this exercise.
- Sign up for an Office 365 developer subscription.
- Navigate to the Office Dev Center
- Under the heading Sign up for an Office 365 Developer Site click Try It Free.
- Fill out the form to obtain your trial O365 subscription.
- When completed, you will have a developer site in the [subscription].sharepoint.com domain located at the root of your subscription (e.g. https://mysubscription.sharepoint.com)
- Enable Yammer for Social Expereince
- Log into [subscription].sharepoint.com
- Click Admin/SharePoint.
- Click Settings.
- Change the Enterprise Social Collaboration setting to Yammer.
- Sign up for an Azure trial subscription
- Navigate to the Azure Portal
- If prompted, log in using the credentials you created for your O365 subscription.
- After logging in, you should see a screen notifying you that you do not have a subscription
- Click Sign Up for Windows Azure.
- Fill out the form to obtain your free trial.
In this exercise you create a new provider-hosted app for your O365 subscription.
- Create the new solution in Visual Studio 2013:
- Launch Visual Studio 2013 as administrator.
- In Visual Studio select File/New/Project.
- In the New Project dialog:
1. Select Templates/Visual C#/Office/SharePoint/Apps.
2. Click App for SharePoint 2013.
3. Name the new project AzureCloudApp and click OK.
- In the New App for SharePoint wizard:
1. Enter the address of a SharePoint site to use for testing the app (NOTE: The targeted site must be based on a Developer Site template)
2. Select Provider-Hosted as the hosting model.
3. Click Next.
4. Select ASP.NET MVC Web Application. 5. Click Next.
6. Select the option labeled Use Windows Azure Access Control Service (for SharePoint cloud apps). 7. Click Finish.
8. When prompted, log in using your O365 administrator credentials. - Test your app
- Press F5 to begin debugging.
- When prompted, log in using your O365 administrator credentials.
- When prompted, click Trust it.
- Verify that the app home page shows and that it properly welcomes you by name.
In this exercise, you will add additional functionality to the app to read data from a SQL Azure database.
- Create a Web Site and SQL Azure database
- Log into the Azure Portal as an administrator.
- Click Web Sites.
- Click New.
- Click Custom Create.
- Enter a URL for the application. (NOTE: URLs must be globally unique, so you will have to choose one not used by another.)
- Select Create New Web Hosting Plan.
- Select an appropriate Region.
- Select Create a free 20MB SQL Database.
- Name the database connection string AzureCloudData.
- Click the Right Arrow.
- In the Specify Database Settings, name the new database AzureCloudData.
1. Select New SQL database server.
2. Name the administrator AzureCloudAdmin and enter a password.
3. Write down the credentials for later!
4. Pick an appropriate Region.
5. Click the checkmark.
- Upload test data to SQL Azure:
- In the Azure portal, click SQL database.
- Click AzureCloudData and copy down your database server information.
- Click Run Transact SQL Queries Against Your Database.
- If prompted to add a firewall rule, click Yes.
- If prompted, select to manage the AzureCloudData database.
- Log in to the database server using the credentials you created earlier.
- Paste the contents of the following script into the query window.
CREATE TABLE [dbo].[Customers]( [ID] [int] IDENTITY(1,1) NOT NULL, [FirstName] [nvarchar](100) NOT NULL, [LastName] [nvarchar](100) NOT NULL, [Company] [nvarchar](100) NULL, [WorkPhone] [nvarchar](100) NULL, [HomePhone] [nvarchar](100) NULL, [EmailAddress] [nvarchar](100) NULL, CONSTRAINT [PK_Customers] PRIMARY KEY CLUSTERED ([ID] ASC)) GO INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Gordon', 'Hee', 'Adventure Works Cycles', '1(340)555-7748', '1(340)555-3737', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Michael', 'Allen', 'Blue Yonder Airlines', '1(203)555-0466', '1(203)555-0071', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('James', 'Alvord', 'City Power and Light', '1(518)555-6571', '1(518)555-8576', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Jeff', 'Phillips', 'Coho Vineyard', '1(270)555-1720', '1(270)555-7810', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Stefen', 'Hessee', 'Contoso, Ltd', '1(407)555-4851', '1(407)555-5411', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Christian', 'Hess', 'Fabrikam, Inc', '1(844)555-0550', '1(844)555-3522', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Cassie', 'Hicks', 'Fourth Coffee', '1(204)555-6648', '1(204)555-2831', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Chris', 'Preston', 'Litware, Inc', '1(407)555-7308', '1(407)555-1700', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Diane', 'Prescott', 'Lucerne Publishing', '1(323)555-3404', '1(323)555-7814', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Michael', 'Hillsdale', 'Margie Travel', '1(802)555-5583', '1(802)555-0246', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Ran', 'Yossi', 'Northwind Traders', '1(250)555-4824', '1(250)555-3653', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Arlene', 'Huff', 'Proseware, Inc', '1(248)555-1267', '1(248)555-0302', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Julia', 'Isla', 'School of Fine Art', '1(270)555-5347', '1(270)555-3401', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Rodrigo', 'Ready', 'Southridge Video', '1(808)555-1110', '1(808)555-4310', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('Shu', 'Ito', 'Trey Research', '1(844)555-5428', '1(844)555-2117', 'someone@example.com') INSERT INTO Customers (FirstName, LastName, Company, WorkPhone, HomePhone, EmailAddress) Values('David', 'Jaffe', 'Wingtip Toys', '1(340)555-4478', '1(340)555-1010', 'someone@example.com') GO
- Click Run.
- Update the Entity Framework package in Visual Studio.
- Right click the AzureCloudAppWeb project and select Manage NuGet Packages.
- Type Entity Framework in the search box.
- Click the Install button for Entity Framework version 6.
- After the package is installed, click Close.
- Add an Entity Framework model.
- In the Solution Explorer, right-click the Models folder in the AzureCloudAppWeb project.
- Select Add/New Item from the context menu.
- In the New Item dialog:
1. Select Visual C#/Data/ASP.NET Entity Data Model.
2. Name the new model AzureCloudDataModel.edmx.
3. Click Add.
- In the Entity Data Model wizard:
1. Click EF Designer from Database.
2. Click Next.
3. Click New Connection. 4. In the Connection Properties dialog:- Enter the database server information you obtained earlier into the Server Name field.
- Select Use SQL Authentication.
- Enter the Administrator credentials for your database server.
- Select AzureCloudData as the database.
- Click Test Connection.
- Click OK.
5. Select Yes, include the sensitive data in the connection string.
6. Click Next.
7. Check Tables.
8. Click Finish.
- Add a controller.
- Build the AzureCloudAppWeb project.
- Right-click the Controllers folder and select Add/Controller.
1. Select MVC5 Controller with views using Entity Framework.
2. Click Add.
3. Select Customer as the Model Class. 4. Select AzureCloudDataEntities as the Data Context Class. 5. Click Add.
- Update the App Manifest
- In the AzureCloudApp project, double-click the AppManifest.xml file.
- Update the Start Page to be AzureCloudAppAWeb/Customers.
- Test your app
- Press F5 to begin debugging.
- When prompted, log in using your O365 administrator credentials.
- When prompted, click Trust it.
- Verify that the customer data appears in the app.
In this exercise, you will deploy the database and app to the O365/Azure environment.
- Register the app in Office 365
- Log into the O365 developer site as an administrator
- From the developer site, navigate to /_layouts/15/appregnew.aspx.
- Click Generate next to Client ID.
- Click Generate next to Client Secret.
- Enter Azure Cloud App as the Title.
- Enter the App Domain for the Azure web site you created earlier (e.g., azurecloudapp.azurewebsites.net)
- Enter the Redirect URI as the reference for the Customers page (e.g. https://azurecloudapp.azurewebsites.net/Customers).
- Click Create.
1. Save the Client ID and Client Secret separately for later use.
- Update the provider-hosted app
- In the AzureCloudApp project open the AppManifest.xml file in a text editor.
- Update the Client ID and App Start page to reflect the values you created earlier.
- Open the web.config file for the AzureCloudAppWeb project.
- Update the Client ID and Client Secret to use the generated values.
- Publish the remote web
- Right click the AzureCloudAppWeb project and select Publish.
- Click Windows Azure Web Sites.
- When prompted, select to deploy the remote web to the existing Azure web site you created earlier.
- Publish the remote web.
- Update information in the Azure Portal
- Return to the Azure Management portal.
- Click Web Sites.
- Select your Azure Web Site.
- Click Configure.
- In the App Settings section, add a ClientId and ClientSecret setting.
- Set the values to the values you generated earlier.
- Click Save.
- Package the SharePoint App
- Right click the AzureCloudApp project and select Publish.
- Click Package the App.
- Enter the Start URL and Client ID for the app.
- Click Finish.
- Publish the App to the Corporate Catalog
- Return to the O365 tenant and select Admin/SharePoint.
- Click Apps/App Catalog.
3.Select Create new app catalog site. - Click OK.
- Fill out the required information for the new app catalog site and click OK.
- Once created, navigate to the new app catalog site.
- In the app catalog site, click Apps for SharePoint.
- Click New.
- Browse to the app package you created earlier.
- Add the app package to the Apps for SharePoint library.
- Add the app to a SharePoint site
- Navigate to a site in your O365 tenancy.
- Click Site Contents. (NOTE: If you are using the Developer site, it may have an older version of the app still installed from testing. You must remove the app from the site AND remove the entry from the �Apps in Testing� list or the new app will not install.)
- Click Add an App.
- Click From Your Organization.
- Click the app installer.
- When prompted, click Trust It.
- Test the App
- Use the tile to launch the app.
- Verify that data from the SQL Azure database appears in the app.
Congratulations! You have completed building a provider-hosted app using Office 365 and Azure.