【发布时间】:2015-07-07 00:07:49
【问题描述】:
我正在制作一个 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);
有人可以帮帮我吗?
提前致谢!
【问题讨论】:
标签: c# asp.net iis asp.net-web-api2 iis-8.5