我正在制作一个Web API 2.
在我的本地机器上调试工作正常。 VS 2013 + IIS 8.0
服务器正在运行Windows 2012 R2 + IIS 8.5 + Plesk v12
当我在本地计算机上调试时,我的所有路由都正常工作。
我正在使用Postman和Fiddler检查API上的所有内容。
当我将它部署到服务器并且发送PUT请求到路由http://example.net/service/Member/Profile/9时,我有一个例外。
我收到以下错误:
HTTP错误401.0 - 未经授权您无权查看 这个目录或页面。
最有可能的原因:经过身份验证的用户无权访问 处理请求所需的资源。
模块:WebDAVModule
通知:ExecuteRequestHandler
处理程序:WebDAVStaticMapping
错误代码:0x80070005
请求的网址:http://example.org/service/Member/Profile/5
物理路径:C:\ Inetpub \ vhosts \ example.org \ httpdocs \ service \ Member \ Profile \ 5
登录方法:匿名
登录用户:匿名
我检查了IIS上的配置,我认为它看起来很好。 匿名身份验证处于活动状态,其他身份验证方法已停用。选择了ApplicationPoolIdentity。
Web API 2背后的代码
路线映射如下:
config.Routes.MapHttpRoute(
name: "EditMember",
routeTemplate: "service/Member/Profile/{id}",
defaults: new { controller = "Members", action = "Update", id = RouteParameter.Optional },
constraints: null
);
它将在控制器中运行此代码:
// PUT: service/Member/5
[ActionName("Update")]
[ResponseType(typeof(void))]
public async Task<IHttpActionResult> PutMembers(int id, MemberUpdate member)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
IEnumerable<Members> memberSearchExist = from search in db.MembersSet
where search.Id == id
select search;
if (!memberSearchExist.Any())
{
return Conflict();
}
try
{
Members memberChanged = memberSearchExist.FirstOrDefault();
memberChanged.Firstname = member.Firstname;
memberChanged.Lastname = member.Lastname;
memberChanged.DateOfBirth = member.DateOfBirth;
memberChanged.Email = member.Email;
db.Entry(memberChanged).State = System.Data.Entity.EntityState.Modified;
await db.SaveChangesAsync();
}
catch (DbUpdateConcurrencyException)
{
if (!MembersExists(id))
{
return NotFound();
}
else
{
throw;
}
}
return StatusCode(HttpStatusCode.NoContent);
}
我正在使用CORS,并且它适用于所有其他事情。
var corsAttr = new EnableCorsAttribute("http://app.example.org, http://localhost:14844", "*", "*");
config.EnableCors(corsAttr);
有人能帮帮我吗?
提前致谢!
答案 0 :(得分:0)
第一个问题是WebDav模块。该模块阻止了PUT和DELETE方法。您可以通过卸载来解决此问题。您可以在此处找到如何执行此操作:https://betimdrenica.wordpress.com/2013/02/05/web-api-on-iis-8-0-405-method-not-allowed-for-put/
第二个问题是HTTP错误404.0 - 未找到,MapRequestHandler 我找到了这个解决方案:https://stackoverflow.com/a/5677618/2660428 on SO我按照此步骤安装了服务器端包含http://www.iis.net/configreference/system.webserver/serversideinclude
最后一个问题是我只能
var corsAttr = new EnableCorsAttribute("http://app.example.org", "*", "*");
config.EnableCors(corsAttr);
现在一切正常。