在控制器中,创建两个Action,即是视图Action,另一个是POST的Action:
HttpClient client = new HttpClient(); HttpContent httpcontent = new StringContent(size.ToJson(), System.Text.Encoding.UTF8, "application/json"); client.PostAsync("http://localhost:9001/api/size", httpcontent) .ContinueWith((postTask) => { postTask.Result.EnsureSuccessStatusCode(); });
Source Code
视图代码:
程序运行,看看是否能正常运行,数据库是否有数据插入?
下面演示更新操作PUT,在控制器中,创建Action,一个显示数据,另一个更新数据:
public ActionResult PutDemo(int id) { var sizes = ApiUtility.Get<Size>("http://localhost:9001/api/size/" + id); var model = sizes.FirstOrDefault(); return View(model); } [HttpPost] public ActionResult PutDemo(Size size) { HttpClient client = new HttpClient(); HttpContent httpcontent = new StringContent(size.ToJson(), System.Text.Encoding.UTF8, "application/json"); client.PutAsync("http://localhost:9001/api/size", httpcontent) .ContinueWith((postTask) => { postTask.Result.EnsureSuccessStatusCode(); }); return RedirectToAction("PutDemo", size.Size_nbr); }
Source Code
视图:
实时演示:
下面Insus.NET再把Delete的功能实现完,在实现删除这个功能时,出现一点点困难:
先在控制器创建操作Action:
public ActionResult DeleteDemo(int id) { var sizes = ApiUtility.Get<Size>("http://localhost:9001/api/size/" + id); var model = sizes.FirstOrDefault(); return View(model); } [HttpPost] public ActionResult DeleteDemo(Size size) { HttpClient client = new HttpClient(); client.DeleteAsync("http://localhost:9001/api/size/" + size.Size_nbr) .ContinueWith((postTask) => { postTask.Result.EnsureSuccessStatusCode(); }); return RedirectToAction("ShowApiData1"); }
Source Code
看到否,在上图中的标记#2中,DeleteAsync方法,它是不接受一个复杂Complex对type。为了不需要对前些天的程序作过多的修改,因此Insus.NET只得对Web API进行修改。这也许是设计Web API时欠缺的思考。
为API接口添加多一个方法重载:
这个Web API来自《创建与使用Web API》http://www.cnblogs.com/insus/p/5019088.html
添加删除视图DeleteDemo.cshtml:
删除功能实时演示:
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦