ASP.NET 5系列教程 (四):向视图中添加服务和发布应用到公有云
向视图中添加服务
现在,ASP.NET MVC 6 支持注入类到视图中,和VC类不同的是,对类是公开的、非嵌套或非抽象并没有限制。在这个例子中,我们创建了一个简单的类,用于统计代办事件、已完成事件和平均优先级的服务。
1. 添加命名为Services 的文件夹,在该文件夹下添加名称为 StatisticsService.cs 的类:
StatisticsService 类代码设计如下:
- using System.Linq;
- using System.Threading.Tasks;
- using TodoList.Models;
- namespace TodoList.Services
- {
- public class StatisticsService
- {
- private readonly ApplicationDbContext db;
- public StatisticsService(ApplicationDbContext context)
- {
- db = context;
- }
- public async Task<int> GetCount()
- {
- return await Task.FromResult(db.TodoItems.Count());
- }
- public async Task<int> GetCompletedCount()
- {
- return await Task.FromResult(
- db.TodoItems.Count(x => x.IsDone == true));
- }
- public async Task<double> GetAveragePriority()
- {
- return await Task.FromResult(
- db.TodoItems.Average(x =>
- (double?)x.Priority) ?? 0.0);
- }
- }
- }
2. 更新Index 视图注入代办事项数据,在文件顶部添加以下代码声明注入的服务:
@inject TodoList.Services.StatisticsService Statistics
添加标记调用 StatisticsService:
- <div>@Html.ActionLink("Create New Todo", "Create", "Todo") </div>
- </div>
- <div class="col-md-4">
- @await Component.InvokeAsync("PriorityList", 4, true)
- <h3>Stats</h3>
- <ul>
- <li>Items: @await Statistics.GetCount()</li>
- <li>Completed:@await Statistics.GetCompletedCount()</li>
- <li>Average Priority:@await Statistics.GetAveragePriority()</li>
- </ul>
- </div>
- </div>
以下是该文件的完整代码:
- @inject TodoList.Services.StatisticsService Statistics
- @{
- ViewBag.Title = "Home Page";
- }
- <div class="jumbotron">
- <h1>ASP.NET vNext</h1>
- </div>
- <div class="row">
- <div class="col-md-4">
- @if (Model.Count == 0)
- {
- <h4>No Todo Items</h4>
- }
- else
- {
- <table>
- <tr><th>TODO</th><th></th></tr>
- @foreach (var todo in Model)
- {
- <tr>
- <td>@todo.Title </td>
- <td>
- @Html.ActionLink("Details", "Details", "Todo", new { id = todo.Id }) |
- @Html.ActionLink("Edit", "Edit", "Todo", new { id = todo.Id }) |
- @Html.ActionLink("Delete", "Delete", "Todo", new { id = todo.Id })
- </td>
- </tr>
- }
- </table>
- }
- <div>@Html.ActionLink("Create New Todo", "Create", "Todo") </div>
- </div>
- <div class="col-md-4">
- @await Component.InvokeAsync("PriorityList", 4, true)
- <h3>Stats</h3>
- <ul>
- <li>Items: @await Statistics.GetCount()</li>
- <li>Completed:@await Statistics.GetCompletedCount()</li>
- <li>Average Priority:@await Statistics.GetAveragePriority()</li>
- </ul>
- </div>
- </div>
3. 在 Startup.cs 文件中注册StatisticsService 类:
- // This method gets called by the runtime.
- public void ConfigureServices(IServiceCollection services)
- {
- // Add EF services to the services container.
- services.AddEntityFramework(Configuration)
- .AddSqlServer()
- .AddDbContext<ApplicationDbContext>();
- // Add Identity services to the services container.
- services.AddDefaultIdentity<ApplicationDbContext, ApplicationUser, IdentityRole>(Configuration);
- // Add MVC services to the services container.
- services.AddMvc();
- services.AddTransient<TodoList.Services.StatisticsService>();
- }
以下是效果图:
发布应用到公有云
发布应用到公有云,你需要申请 Microsoft Azure 帐号,如果没有,可以通过以下链接注册:activate your MSDN subscriber benefits 或 sign up for a free trial.
1. 右键点击 TodoList 工程> 发布
2. 在发布对话框中,点击 Microsoft Azure Websites 并登陆公有云帐号。
3. 点击 New。
4. 输入site name 和region。如果你之前没有创建过数据服务器,需要新建,否则可以使用原有的数据库服务器。
数据库服务器是一个宝贵的资源。最好使用现有服务器进行测试和开发。然而由于没有密码校验机制,密码输入错误时不会有错误提示,只有在应用实际访问数据库时才会报错。
5. 在Connection 标签中点击> Next。
6. 在Settings 标签中,选择 KRE 版本。
7. 点击 Publish。
8. 好了,至此你的应用就发布到公有云了,以下是效果图。
以上内容,介绍了如何向视图中添加服务和发布应用到公有云中,大家可以将这些知识运用到实际开发中。开发时还可以借助一些工具。ComponentOne Studio for ASP.NET 是ASP.NET平台上的一整套完备的开发工具包,用于在各种浏览器中创建和设计具有现代风格的Web应用程序。
原文链接:http://www.asp.net/vnext/overview/aspnet-vnext/vc#inj
系列文章目录:
ASP.NET 5系列教程 (四):向视图中添加服务和发布应用到公有云的更多相关文章
- ASP.NET 5系列教程 (六): 在 MVC6 中创建 Web API
ASP.NET 5.0 的主要目标之一是统一MVC 和 Web API 框架应用. 接下来几篇文章中您会了解以下内容: ASP.NET MVC 6 中创建简单的web API. 如何从空的项目模板中启 ...
- ASP.NET 5系列教程(七)完结篇-解读代码
在本文中,我们将一起查看TodoController 类代码. [Route] 属性定义了Controller的URL 模板: [Route("api/[controller]") ...
- ASP.NET 5系列教程 (三):view components介绍
在ASP.NET MVC 6中,view components (VCs) 功能类似于虚拟视图,但是功能更加强大. VCs兼顾了视图和控制器的优点,你可以把VCs 看作一个Mini 控制器.它负责控制 ...
- ASP.NET Identity系列教程(目录)
$(document).ready(function(){ $("#hide").click(function(){ $(".en").hide(); }); ...
- C#微信公众号开发系列教程四(接收普通消息)
微信公众号开发系列教程一(调试环境部署) 微信公众号开发系列教程一(调试环境部署续:vs远程调试) C#微信公众号开发系列教程二(新手接入指南) C#微信公众号开发系列教程三(消息体签名及加解密) C ...
- 【ASP.NET Identity系列教程(一)】ASP.NET Identity入门
注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- 【ASP.NET Identity系列教程(二)】运用ASP.NET Identity
注:本文是[ASP.NET Identity系列教程]的第二篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- 【ASP.NET Identity系列教程(三)】Identity高级技术
注:本文是[ASP.NET Identity系列教程]的第三篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- Android Studio系列教程四--Gradle基础
Android Studio系列教程四--Gradle基础 2014 年 12 月 18 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://stormzhang ...
随机推荐
- swift 代码添加lable
let lable1 = UILabel(frame: CGRect(x: CGFloat(self.view.bounds.width/2-20), y: CGFloat(history.frame ...
- clone()与clone(true)的区别
clone()方法用于复制一个元素,但是被复制出来的元素不具备复制的功能,如果希望被复制出来的元素也具备复制的功能,需要给clone()方法加上true这个参数,即clone(true). 例如: & ...
- Spring 依赖注入的方式
Spring 支持3中依赖注入的方式 1.属性注入 通过setter 方法注入Bean的属性或依赖的对象. <bean id = " " class = " &q ...
- 运行时报错-Verify the Developer App certificate for youraccount is trusted on your device. Open Settings on Mayoyi_sakura and navigate to General -> Device Management, then select your
解决方法:打开手机设置->通用->设备管理,找到编辑工程时的ID资料,点击允许即可.
- (引用) unittest测试驱动之执行测试(三)
转载:http://www.wtoutiao.com/p/ydeoyY.html 在unittest的模块中,提供了TestRunner类来进行运行测试用例,在实际的应用中,经常使用的是TextTes ...
- knockout.js $index 做列表索引小技巧
我们都知道,在foreach binding中,使用$index可以得到基于0的索引序号,但在列表显示中,我们更希望这个索引是从1开始的,怎么处理呢? 这里,有个小技巧:使用$index() + 1, ...
- php基础-转义字符
1.php是弱类型语言,定义变量时无需要定义 2.标量类型:整形.浮点型.字符串类型.布尔型 复合类型:数组.对象 其它类型:资源类型(resource如数据库连接,打开文件句柄,资源在不需要时都要释 ...
- 云计算和大数据时代网络技术揭秘(十二)自定义网络SDN
软件定义网络——SDN SDN是网络技术热点,即软件定义网络,OpenFlow是实现SDN思想的一个框架标准, open是指公开.开放,具体为控制平面的规则由各个通信厂家自定义变为公开的技术标准, f ...
- 校验两次密码一致的js代码
function checkpasswd(){ var passwd = document.getElementByIdx_x_x_xx_x('passwd').value; var repasswd ...
- Windows 打印控件
Windows窗体的PrintDocument组件用于设置一些属性,这些属性说明,在基于Windows的应用程序中要打印说明内容以及打印文档的能力,可将它与PrintDialog组件一起使用来控制文档 ...