【发布时间】:2017-03-31 03:13:45
【问题描述】:
我创建了一个简单的 Web api 服务来获取和发布用户数据。
Localhost 一切正常。但是当我在服务器上托管服务时,当我从 PostMan/Browser 调用它时,Get Method 工作正常。但是 Post Methods 总是返回 “请求的资源不支持 http 方法 'GET'。”状态:405 方法不允许。
我在这里感到困惑的一件事,即我请求了一个 POST 呼叫,但状态消息显示“GET”错误。为什么应该这样?如果是CORS问题?我通过在应用程序级别(Web.Config 以及 Nuget 包管理器 Cors)在 Internet 上搜索答案,尝试在各种场景/方面启用 CORS。仍然得到 405 Method Not Allowed。下面粘贴了我的 API 代码:
控制器命名空间:
using MySql.Data.MySqlClient;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using System.Web.Http.Cors;
控制器
public class UsersController : ApiController
{
[Route("api/Users/GetUsers/{UserId}")]
[HttpGet]
public IEnumerable<User> GetUsers(int UserId)
{
try
{
List<User> userlist = new List<User>();
MySqlCommand cmd = new MySqlCommand("GetUsers");
cmd.Parameters.AddWithValue("aUserId", UserId);
cmd.CommandType = CommandType.StoredProcedure;
DataTable dt = obj.GetData(out ErrorMsg, cmd);
// Did Some Stuff and Returns Model;
return userlist;
}
catch(Exception ex)
{
// Written Error Log & Returns Empty Model;
}
}
[Route("api/Users/SaveUser")]
[HttpPost]
public IEnumerable<User> SaveUser([FromBody]dynamic request)
{
try
{
string UserName = request.Param_Name;
string Email = request.Param_Email;
List<User> userlist = new List<User>();
MySqlCommand cmd = new MySqlCommand("UserSave");
cmd.Parameters.AddWithValue("aUserName", UserName);
cmd.Parameters.AddWithValue("aEmail", Email);
cmd.CommandType = CommandType.StoredProcedure;
DataTable dt = obj.GetData(out ErrorMsg, cmd);
UserAuthenticate userdata;
// Did Some Stuff and returns UserModel;
return userlist;
}
catch(Exception Ex)
{
// Written Error Log & Returns Empty Model with Error Message;
}
}
[Route("api/Users/SaveUserModel")]
[HttpPost]
public IEnumerable<User> SaveUserModel([FromBody]User request)
{
try
{
string Param_UserName = request._UserName;
string Param_Email = request._Email;
List<User> userlist = new List<User>();
MySqlCommand cmd = new MySqlCommand("UserSave");
cmd.Parameters.AddWithValue("aUserName", Param_UserName);
cmd.Parameters.AddWithValue("aEmail", Param_Email );
cmd.CommandType = CommandType.StoredProcedure;
DataTable dt = obj.GetData(out ErrorMsg, cmd);
UserAuthenticate userdata;
// Did Some Stuff and returns UserModel;
return userlist;
}
catch(Exception Ex)
{
// Written Error Log & Returns Empty Model with Error Message;
}
}
}
型号
public class User
{
public int _UserID { get; set; }
public string _Email { get; set; }
public string _UserName { get; set; }
}
Web.Config
Web.Config File Pasted here in Image
WebApi.Config
命名空间
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http.Headers;
using System.Web.Http;
using System.Web.Http.Cors;
WebApiConfig 类
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
// Web API configuration and services
var cors = new EnableCorsAttribute("*", "*", "*");
config.EnableCors(cors);
// Web API routes
config.MapHttpAttributeRoutes();
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);
config.Formatters.JsonFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));
}
}
以上邮递员请求的标头
Access-Control-Allow-Methods →*
Access-Control-Allow-Origin →*
Access-Control-Request-Headers →: *
Access-Control-Request-Method →: *
Allow →POST
Cache-Control →no-cache
Content-Length →72
Content-Type →application/json; charset=utf-8
Date →Wed, 16 Nov 2016 17:50:03 GMT
Expires →-1
Pragma →no-cache
Server →Microsoft-IIS/7.5
X-AspNet-Version →4.0.30319
感谢您的帮助!!为这个错误浪费了一天时间。
【问题讨论】:
-
你是如何调用这个 API 的?什么方法?
-
通过邮递员我打电话。方法是 SaveUser 和 SaveUserModel。附加邮递员请求和响应图像。以及粘贴标题
-
你确定吗?您正在选择 POST 吗?
-
@viveknuna 是的!我确定
-
你在打什么网址?
标签: c# asp.net-web-api asp.net-web-api2