Web API学习基础一

  1. 开发环境

    VS2012、.NET 4.5

  2. 创建项目

    VS2012->文件->新建->项目,选择ASP.NET MVC 4Web应用程序
    Web API学习基础一_第1张图片

  3. 选择Web API项目,并使用Razor引擎

    Web API学习基础一_第2张图片

  4. 目录结构

    Web API学习基础一_第3张图片

在App_Start中,RouteConfig.cs文件配置MVC的路由规则,WebApiConfig.cs配置WebApi的路由规则
在Controllers文件夹中编写控制器,可以编写MVC控制器也可以编写WebAPI的控制,继承的类不一样

  1. Web API路由
 config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );
路由决定了URL的格式。默认路由的URL格式为http://localhost/api/Student/1, 表示访问Student控制器,并传递id  

=1

6.访问规则
Get方式:查询,无负做用,不管执行多少次都不会改变系统的状态
Put方式:修改,执行一次或多次,对系统状态的改变是一样的
Post方式:新增
Delete方式:删除,执行一次或多次,对系统状态的改变是一样的

通过Get方式访问,会查找以Get开头的所有Action,并匹配对应的参数,如果查找到两个方法,则会报错。所以Get开头的Action,必须参数不一样
Put、Post、Delete也是一样
示例:

 // GET api/values
        public IEnumerable<string> Get()
        {
            return new string[] { "value1", "value2" };
        }

        // GET api/values/5
        public string Get(int id)
        {
            return "value";
        }

可以通过如下方式访问不带参数的Get方法:
GET http://localhost/Student/

也可以通过给Action加上Attribute改变访问方式

 // GET api/values/5
        [HttpPut]
        public string Get(int id)
        {
            return "value";
        }

添加HttpPut之后就只能通过Put方式访问了

  1. 如何通过Action名称访问对应Action
    可以在WebApiConfi.cs文件中增加路由规则
config.Routes.MapHttpRoute(
               name: "DefaultApi",
               routeTemplate: "api/{controller}/{action}/{id}",
               defaults: new { id = RouteParameter.Optional }
           );

这样就可以通过action名称访问对应的action
如果Action不是以Get、Post等方式开头,则必须添加HttpGet等Attribute。否则会出现访问错误。

你可能感兴趣的:(web-api)