使用Visual Studio Code开发Asp.Net Core WebApi学习笔记(二)-- Web Api Demo


上一篇里,我已经建立了一个简单的Web-Demo应用程序。这一篇将记录将此Demo程序改造成一个Web Api应用程序。

一、添加ASP.NET Core MVC包

1. 在project.json文件添加Microsoft.AspNetCore.Mvc包

{

  "version": "1.0.0-*",

  "buildOptions": {

    "debugType": "portable",

    "emitEntryPoint": true

  },

  "dependencies": {

    "Microsoft.NETCore.App": {

      "type": "platform",

      "version": "1.0.0"

    },

    "Microsoft.AspNetCore.Server.Kestrel": "1.0.0",

    "Microsoft.AspNetCore.Mvc": "1.0.0"

  },

  "frameworks": {

    "netcoreapp1.0": {

      "imports": "dnxcore50"

    }

  }

}

2. 在cmd窗口使用 dotnet restore 将新添加的包还原至本地

 

二、修改Startup.cs文件内容,添加Asp.Net Mvc能力


using Microsoft.AspNetCore.Builder;

using Microsoft.Extensions.DependencyInjection;


namespace WebApiFrame

{

    public class Startup

    {

        public void ConfigureServices(IServiceCollection services)

        {


            // 注入MVC框架

            services.AddMvc();

        }


        public void Configure(IApplicationBuilder app)

        {

            // 添加MVC中间件

            app.UseMvc();

        }

    }

}

三、新建Controller,编写Web Api方法

1. 控制器UsersController

using System;

using Microsoft.AspNetCore.Mvc;

using WebApiFrame.Models;


namespace WebApiFrame.Controller

{


    [Route("api/[controller]")]

    public class UsersController : Microsoft.AspNetCore.Mvc.Controller

    {


        [HttpGet("{id}")]

        public IActionResult Get(int id)

        {

            var user = new User() { Id = id, Name = "Name:" + id, Sex = "Male" };

            return new ObjectResult(user);

        }


        [HttpPost]

        public IActionResult Post([FromBody] User user){

            if(user == null){

                return BadRequest();

            }


            // TODO:新增操作

            user.Id = new Random().Next(1, 10);

            return CreatedAtAction("Get", new { id = user.Id }, user);

        }


        [HttpPut("{id}")]

        public IActionResult Put(int id, [FromBody] User user){

            if(user == null){

                return BadRequest();

            }


            // TODO: 更新操作

            return new NoContentResult();

        }


        [HttpDelete("{id}")]

        public void Delete(int id){

            // TODO: 删除操作

            

        }

    }

}

不同于之前的ASP.NET MVC版本,ASP.NET Core MVC里实现Web Api的控制器都继承自唯一的一个基类Controller。

2. 模型User.cs

namespace WebApiFrame.Models

{

    public class User

    {

        public int Id { get; set; }

        public string Name { get; set; }

        public string Sex { get; set; }

    }

}


最终文件夹结构如下图

 

四、启动调试,使用Fiddler工具调试Web Api接口

1. GET Request

GET Response

2. POST Request

POST Response

POST响应码为201,表示资源创建成功。

在响应头里有一个Location属性,这是一个导航属性,属性值是一个url地址,直接指向了刚刚Post成功的资源地址。

3. PUT Request

PUT Response

PUT为更新操作。按照规范,当服务更新操作执行成功后,直接通过响应码204告诉客户端调用成功,默认没有响应body。

4. DELETE Request

DELETE Response

DELETE为删除操作。按照规范,需要通过响应码判断是否成功(200)还是失败(500),默认没有响应body。

原文地址:http://www.cnblogs.com/niklai/p/5658876.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值