ASP.NET 5探险(7):使用混合型控制器方便实现单页应用
2015-08-07 17:26
633 查看
(此文章同时发表在本人微信公众号“dotNET每日精华文章”,欢迎右边二维码来关注。)
题记:由于在ASP.NET 5中,MVC和WEB API的技术栈合并了,所以开发混合型Controller也成为可能。
众所周知,在ASP.NET MVC 5和WEB API 2时代,两者的技术栈是独立的(开发团队也是独立的)。虽然后来两者都可以融合到OWIN中运行在一起,但是两者的控制器(Controller)代码是不能写在一起的(因为两者的基类不一致)。诚然,MVC控制器也可以通过返回Json数据来实现类似WEB API控制器的效果,但是所体现的设计效果并不是纯粹的REST API。
可能微软也意识到并行提供两套技术栈,不仅给自己的开发带来维护难度,也给用户的学习和开发带来困难。所以,在ASP.NET 5中,两者在技术栈上进行了统一,也就是在MVC中可以开发WEB API。这样的技术融合最大的体现的就是路由映射的机制。关于ASP.NET 5中的路由机制,我就不赘述了,大家可以参考其他资料,比如《解读ASP.NET 5 & MVC6系列(11):Routing路由》(/article/1307937.html)。
为了做一个SPA的示例,我尝试使用了混合型控制器来同时支持视图的处理和REST数据接口的处理,这样带来的好处是不需要为了MVC和REST API分别创建两个控制器,且能同时符合MVC和REST API的Action和路由风格。可能用文字很难描述出混合型控制器的特点,还是直接来看代码吧。
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
在上面的代码中,Index这个Action会返回一个视图(Index.cshtml)给用户。在这个cshtml文件中,主要是利用Layout.cshtml来获得统一的母版,只包含很少的Razor代码,而使用jQuery和Knockout来加载和动态展示数据。其中加载数据是通过GetAll这个Action,获取地址还是利用"@Url.Action("GetAll")"来得到,而实际访问是GET“/User/api”。
同样,Edit这个Action会返回一个视图(Edit.cshtml)用于编辑用户的信息。加载用户的单条数据是通过GetById这个Action,实际访问是GET“/User/api/[userid]”。当需要修改数据的时候,是使用EditById这个Action,实际访问地址是PUT “/User/api/[userid]”。
这个控制器的代码也可以通过代码片段来查看:http://git.oschina.net/ike/codes/8avtl3u2p6g1ik09c5snz
题记:由于在ASP.NET 5中,MVC和WEB API的技术栈合并了,所以开发混合型Controller也成为可能。
众所周知,在ASP.NET MVC 5和WEB API 2时代,两者的技术栈是独立的(开发团队也是独立的)。虽然后来两者都可以融合到OWIN中运行在一起,但是两者的控制器(Controller)代码是不能写在一起的(因为两者的基类不一致)。诚然,MVC控制器也可以通过返回Json数据来实现类似WEB API控制器的效果,但是所体现的设计效果并不是纯粹的REST API。
可能微软也意识到并行提供两套技术栈,不仅给自己的开发带来维护难度,也给用户的学习和开发带来困难。所以,在ASP.NET 5中,两者在技术栈上进行了统一,也就是在MVC中可以开发WEB API。这样的技术融合最大的体现的就是路由映射的机制。关于ASP.NET 5中的路由机制,我就不赘述了,大家可以参考其他资料,比如《解读ASP.NET 5 & MVC6系列(11):Routing路由》(/article/1307937.html)。
为了做一个SPA的示例,我尝试使用了混合型控制器来同时支持视图的处理和REST数据接口的处理,这样带来的好处是不需要为了MVC和REST API分别创建两个控制器,且能同时符合MVC和REST API的Action和路由风格。可能用文字很难描述出混合型控制器的特点,还是直接来看代码吧。
public class UserController : Controller { private AccountManager _accountManager; public UserController(AccountManager accountManager) { _accountManager = accountManager; } //下面是mvc的action // GET: /<controller>/ public IActionResult Index() { return View(); } public IActionResult Edit(string id) { ViewBag.Id = id; return View(); } //下面是api的action [HttpGet("[controller]/api")] public async Task<BasePagingListDto<UserDto>> GetAll(int page = 1, int pageSize = 10) { var query = _accountManager.UserManager.Users; var total = await query.CountAsync(); var users = await query.Skip((page - 1) * pageSize).Take(pageSize).ToListAsync(); var dto = new BasePagingListDto<UserDto>(); dto.Items = users.ConvertAll(user => Mapper.Map<UserDto>(user)); dto.Total = total; return dto; } [HttpGet("[controller]/api/{id}")] public async Task<IActionResult> GetById(string id) { var user = await _accountManager.UserManager.FindByIdAsync(id); if (user == null) return HttpNotFound(); var dto = Mapper.Map<UserDto>(user); return new ObjectResult(dto); } [HttpPut("[controller]/api/{id}")] public async Task<IActionResult> EditById(string id, UserDto dto) { if (ModelState.IsValid) { var user = await _accountManager.UserManager.FindByIdAsync(id); if (user == null) return HttpNotFound(); dto.SetValue(user); await _accountManager.UserManager.UpdateAsync(user); return new HttpStatusCodeResult((int)HttpStatusCode.Accepted); } return new HttpStatusCodeResult((int)HttpStatusCode.BadRequest); } }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
在上面的代码中,Index这个Action会返回一个视图(Index.cshtml)给用户。在这个cshtml文件中,主要是利用Layout.cshtml来获得统一的母版,只包含很少的Razor代码,而使用jQuery和Knockout来加载和动态展示数据。其中加载数据是通过GetAll这个Action,获取地址还是利用"@Url.Action("GetAll")"来得到,而实际访问是GET“/User/api”。
同样,Edit这个Action会返回一个视图(Edit.cshtml)用于编辑用户的信息。加载用户的单条数据是通过GetById这个Action,实际访问是GET“/User/api/[userid]”。当需要修改数据的时候,是使用EditById这个Action,实际访问地址是PUT “/User/api/[userid]”。
这个控制器的代码也可以通过代码片段来查看:http://git.oschina.net/ike/codes/8avtl3u2p6g1ik09c5snz
相关文章推荐
- 博客园山寨版(asp.net mvc 开源)
- aspxasp.net ICallbackEventHandler实现免刷新【客户端回调】
- 【asp.net】GridView中模板的使用
- Asp.NET MVC X.PageList.MVC 分页详解以及自定义样式
- ASP.NET+C#面试题
- asp.net—四种控件集
- asp.net新闻列表生成静态页之批量和单页生成
- 发布ASP.NET MVC 4.0 网站到Web服务器上遇到的若干问题
- II7下Framework2.0转为Framework4.0 部署后找不到aspx文件的错误
- 【ASP.NET】视频总结
- Aspose.Cells.dll的运用
- ASP.Net在web.config中设置上传文件的大小方法 (转)
- [CasperJS] 模拟登陆人人网
- ASPxPopupControl 弹窗不显示上一次内容的方法
- ASP.NET.4 高级程序第4版 第3章Web窗体
- ASP.Net服务端基本控件介绍
- CasperJS 介绍以及Windows上安装介绍
- ASP.NET MVC — 第 4 天
- 在AspNet.WebApi中使用Razor
- ASP.NET CSS 小结