如何将Web API添加到现有的ASP.NET MVC(5)Web应用程序项目?

lko*_*lko 141 c# asp.net asp.net-mvc asp.net-web-api asp.net-mvc-5

假设您在创建新的MVC(5)项目时忘记勾选Web API复选框(将其添加到项目中),您需要做什么才能添加Web API并使其正常工作?

有一堆迁移问题,但似乎都没有将Web API添加到MVC 5项目的完整和最新步骤,而且似乎已经从一些旧的答案中改变了.

将Web API添加到MVC 4

添加GlobalConfiguration.Configure(WebApiConfig.Register)MVC 4

lko*_*lko 246

更新MVC项目

使用Nuget获取最新的Web API.

项目 - 右键单击​​ - 管理Nuget包 - 搜索Web API(Microsoft ASP.NET Web API ...)并将其安装到您的MVC项目中.

然后,您仍然需要使Web API路由工作.来自Microsoft的配置ASP.NET Web API 2

将WebApiConfig.cs添加到App_Start /文件夹

using System.Web.Http;

namespace WebApplication1
{
    public static class WebApiConfig
    {
        public static void Register(HttpConfiguration config)
        {
            // TODO: Add any additional configuration code.

            // Web API routes
            config.MapHttpAttributeRoutes();

            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );

        // WebAPI when dealing with JSON & JavaScript!
        // Setup json serialization to serialize classes to camel (std. Json format)
        var formatter = GlobalConfiguration.Configuration.Formatters.JsonFormatter;
        formatter.SerializerSettings.ContractResolver =
            new Newtonsoft.Json.Serialization.CamelCasePropertyNamesContractResolver();
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

如果您有MVC项目,它将具有Global.asax.cs,添加新路由.Global.asax.cs路由的顺序至关重要.请注意,有过时的示例使用 WebApiConfig.Register

将此行添加到Global.asax.cs: GlobalConfiguration.Configure(WebApiConfig.Register);

protected void Application_Start()
{
    // Default stuff
    AreaRegistration.RegisterAllAreas();

    // Manually installed WebAPI 2.2 after making an MVC project.
    GlobalConfiguration.Configure(WebApiConfig.Register); // NEW way
    //WebApiConfig.Register(GlobalConfiguration.Configuration); // DEPRECATED

    // Default stuff
    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);
}
Run Code Online (Sandbox Code Playgroud)

WebAPI帮助

要获得(非常)有用的WebAPI帮助页面,请安装WebAPI.HelpPage.请参阅http://channel9.msdn.com/Events/Build/2014/3-644 (约42分钟).它看起来非常有用!

Nuget控制台: Install-Package Microsoft.AspNet.WebApi.HelpPage

要验证WebAPI是否正常工作:

到controllers文件夹 - >添加新项 - > Web API Controller Class.

public class TestController : ApiController
{
    //public TestController() { }

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

    // GET api/<controller>/5
    public string Get(int id)
    {
        return "value";
    }
    //...
}
Run Code Online (Sandbox Code Playgroud)

现在,您可以像往常一样在IE/FF/Chrome中进行测试,或者在JavaScript控制台中进行非测试测试.

(只有URL中的控制器将调用新Web API控制器中的GET()操作,它会根据REST自动映射到方法/操作,例如PUT/POST/GET/DELETE.您无需调用他们通过像MVC一样的动作)URL直接:

http://localhost:PORT/api/CONTROLLERNAME/
Run Code Online (Sandbox Code Playgroud)

或者使用jQuery查询控制器.运行项目,打开控制台(IE中的F12)并尝试运行Ajax查询.(检查您的PORT&CONTROLLERNAME)

$.get( "http://localhost:PORT/api/CONTROLLERNAME/", function( data ) {
    //$( ".result" ).html( data );
    alert( "Get data received:" + data);
});
Run Code Online (Sandbox Code Playgroud)

附注:在项目中组合MVC和Web API时需要考虑一些优点/缺点

WebAPI帮助验证: http://localhost:PORT/help

  • "Global.asax.cs路线的顺序至关重要"+1 (13认同)
  • 我正在使用调用WebApiConfig.Register(GlobalConfiguration.configuration)的"旧方式"; 而且我再也无法调试了.我会开始调试,它永远不会达到我的控制器功能.我改为"新方式"GlobalConfiguration.Configure(WebApiConfig.Register); 问题得到了解决. (3认同)

归档时间:

查看次数:

92470 次

最近记录:

6 年 前