解决.NET Web API生成的Help无Controller说明&服务端接收不到请求

今天在用.NET Web API写一个接口的时候遇到一个问题。在Controller中新加了一个方法,客户端就不能请求接口了,当时建WEB API项目是用的VS默认设置,在服务端打断点一直没有进去,而APP端一直报服务端响应失败!奇怪的是连生成的Help API说明都没Controller说明。

这样也办法用WebAPITestClient测试,后来用想到了用HttpRequester插件请求一下接口果然出错了。

<Error><Message>出现错误。</Message><ExceptionMessage>找到了与该请求匹配的多个操作: 
类型 Lanhu.seoDayCharge.API.Controllers.StatsController 的 KeywordsRankDayList
类型 Lanhu.seoDayCharge.API.Controllers.StatsController 的 KeywordsList</ExceptionMessage><ExceptionType>System.InvalidOperationException</ExceptionType><StackTrace>   在 System.Web.Http.Controllers.ApiControllerActionSelector.ActionSelectorCacheItem.SelectAction(HttpControllerContext controllerContext)
   在 System.Web.Http.ApiController.ExecuteAsync(HttpControllerContext controllerContext, CancellationToken cancellationToken)
   在 System.Web.Http.Dispatcher.HttpControllerDispatcher.&lt;SendAsync&gt;d__1.MoveNext()</StackTrace></Error>

看来是路由出错了,找到测试路由的地方:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.linq;
  4. using System.Web.Http;
  5. namespace Lanhu.seoDayCharge.API
  6. {
  7. public static class WebApiConfig
  8. {
  9. public static void Register(HttpConfiguration config)
  10. {
  11. // Web API 配置和服务
  12. // Web API 路由
  13. config.MapHttpAttributeRoutes();
  14. config.Routes.MapHttpRoute(
  15. name: "DefaultApi",
  16. routeTemplate: "api/{controller}/{id}",
  17. defaults: new { id = RouteParameter.Optional }
  18. );
  19. }
  20. }
  21. }

细心的同学可能看到,上面路由规则配置是没有action的,加上action就ok了。

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

问题原因:

微软的web api是严格遵循realfull设计思想的,其实默认webapi只有 get,post,delete,put 4种方法名。四中方法名,根据你提交的形式来区别。

换句话说用vs创建WEB API项目时路由默认是没有加Action的,这一点和ASP.NET mvc是有区别的。也就是如果在路由规则中没有定义action部分,在一个Web API的Controller里面只能有一个post方式提交的方法,如果新加了一个post方式提交的方法就会出现上面提到错误。

原文地址:https://www.cnblogs.com/yelanggu/p/10195159.html

时间: 2024-10-03 19:48:05

解决.NET Web API生成的Help无Controller说明&服务端接收不到请求的相关文章

asp.net core web api 生成 swagger 文档

asp.net core web api 生成 swagger 文档 Intro 在前后端分离的开发模式下,文档就显得比较重要,哪个接口要传哪些参数,如果一两个接口还好,口头上直接沟通好就可以了,如果接口多了就有点不适用了,没有接口文档会大大提高前后端的沟通成本.而 asp.net core 可以通过 Swashbuckle.AspNetCore 很方便的集成 swagger 文档,相比之前 nodejs(express) 和 swagger 集成就很麻烦了,大概这就是强类型语言的优势吧.C#

为ASP.NET WEB API生成人性化说明文档

一.为什么要生成说明文档 我们大家都知道,自己写的API要供他人调用,就需要用文字的方式将调用方法和注意事项等写成一个文档以更好的展示我们设计时的想法和思路,便于调用者更加高效的使用我们的API. 当然,您可以不借助任何工具,自己手工写文档,然后做成chm或者html的形式交给客户,就是效率有点低,并且在API更改后有需要手工更改说明文档. 那有没有一种既方便,又能在API发生改变时,自动更新说明文档呢?答案是肯定的. 二.自动生成说明文档的具体实现 我们这里主要是将GlobalConfigur

使用Swagger来生成asp.net core Web API 文档

对于构建一个消费应用程序,理解API的各个方法对开发这是一个不小的挑战.为了使你的API更利于阅读.使用Swagger为你的Web API生成好的文档和帮助页,.NET Core实现了Swashbuckle.AspNetCore,使用Swagger是非常简单的,只需添加一组Nuget包和修改Startup就可以搞定. .Swashbuckle.AspNetCore 开源项目, ASP.NET Core Web API生成Swagger文档的 .Swagger是一个机器可读的restful风格的a

本地发布Web API数据服务接口时,无法访问服务接口问题的解决

最近在做Web API接口,为前端展示提供数据服务,在公司发布接口服务一切都正常,但是回到家用自己的笔记本时,问题就来了,各种类型的错误,500,404..."您要找的资源已被删除.已更名或暂时不可用."是出现最多的家伙... 至于服务的发布,大家可以参考这篇文章:http://www.jb51.net/article/29787.htm,很不错,大家都喜欢的图文并茂教程,最主要的是跟我们常用的网站发布方式能够对号入座,2的5次方个赞!!! 在公司,按照上面的方式发布网站一切都那么地顺

ASP.NET Web API路由系统:路由系统的几个核心类型

虽然ASP.NET Web API框架采用与ASP.NET MVC框架类似的管道式设计,但是ASP.NET Web API管道的核心部分(定义在程序集System.Web.Http.dll中)已经移除了对System.Web.dll程序集的依赖,实现在ASP.NET Web API框架中的URL路由系统亦是如此.也就是说,ASP.NET Web API核心框架的URL路由系统与ASP.NET本身的路由系统是相对独立的.但是当我们采用基于Web Host的方式(定义在程序集System.Web.H

ASP.NET Web API的Controller是如何被创建的?

Web API调用请求的目标是定义在某个HttpController类型中的某个Action方法,所以消息处理管道最终需要激活目标HttpController对象.调用请求的URI会携带目标HttpController的名称,该名称经过路由解析之后会作为路由变量保存到一个HttpRouteData对象中,而后者会被添加到代表当前请求的HttpRequestMessage对象的属性字典中.ASP.NET Web API据此解析出目标HttpController的类型,进而实现针对目标HttpCon

[ASP.NET MVC 小牛之路]18 - Web API

原文:[ASP.NET MVC 小牛之路]18 - Web API Web API 是ASP.NET平台新加的一个特性,它可以简单快速地创建Web服务为HTTP客户端提供API.Web API 使用的基础库是和一般的MVC框架一样的,但Web API并不是MVC框架的一部分,微软把Web API相关的类从 System.Web.Mvc 命名空间下提取了出来放在 System.Web.Http 命名空间下.这种理念是把 Web API 作为ASP.NET 平台的核心之一,以使Web API能使用在

ASP.NET Web API中的依赖注入

小分享:我有几张阿里云优惠券,用券购买或者升级阿里云相应产品最多可以优惠五折!领券地址:https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=ohmepe03 什么是依赖注入 依赖,就是一个对象需要的另一个对象,比如说,这是我们通常定义的一个用来处理数据访问的存储,让我们用一个例子来解释,首先,定义一个领域模型如下: namespace Pattern.DI.MVC.Models{ public cl

WCF与Web API在应用上的选择

在最近发布的Visual  Studio 2012及.NET 4.5中, 微软正式推出新的网络服务框架ASP.NET Web API.作为ASP.NET MVC  4的一部分,ASP.NET Web API这套开源框架的设计目的是简化RESTful服务的开发和使用. ASP.NET Web API 与之前的内建HTTP服务解决方案的不同之处在于,它一开始就是围绕HTTP协议及其消息语义构建起来的.与WCF  REST或ASP.NET AJAX加ASMX相比,它不是对现有框架的增强,而是一个全新的