开发环境
VS2012、.NET 4.5
创建项目
VS2012->文件->新建->项目,选择ASP.NET MVC 4Web应用程序
选择Web API项目,并使用Razor引擎
目录结构
在App_Start中,RouteConfig.cs文件配置MVC的路由规则,WebApiConfig.cs配置WebApi的路由规则
在Controllers文件夹中编写控制器,可以编写MVC控制器也可以编写WebAPI的控制,继承的类不一样
- 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方式访问了
- 如何通过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。否则会出现访问错误。