我一直在追查一个问题并决定尽可能对该问题进行最基本的重现,希望简化的问题能够帮助我解决这个问题。
当我通过 JavaScript 中的 AJAX 发布到 Web 服务时,我收到 401 错误。我将提供尽可能多的信息以及我尝试过的所有故障排除步骤。
我在我的网站根目录下创建了一个测试页面,并尝试使用纯 JS 和 jQuery 进行 AJAX 调用,结果相同。我已将 jquery 注释掉:
页:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//" "http://www.w3.org/TR/html4/loose.dtd">
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script type="text/javascript">
/*$(document).ready(function() {
$('#button').click(function() {
var ID = 2;
var firstname = $('#First_Name').val();
var lastname = $('#Last_Name').val();
$.ajax({
type: 'POST',
url: '/service/name/service.aspx/ChangeName',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
data: '{ "ID": "' + ID + '", "firstName": "' + firstname + '", "lastName": "' + lastname + '" }',
success: function() {
console.log('success');
},
error: function(d) {
console.log(d.responseText);
}
});
});
});*/
function runAjax() {
//Create Http request depending on browser
var xmlhttp;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");}
xmlhttp.onreadystatechange=function(){
if (xmlhttp.readyState==4 && xmlhttp.status==200){
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;}
}
// Function to create
var url = "/service/name/service.aspx/ChangeName";
xmlhttp.open("POST",url,true);
xmlhttp.setRequestHeader("Content-Type", "application/json; charset=utf-8");
var data=JSON.stringify({ "ID": "2", "firstName": "John", "lastName": "Doe" });
xmlhttp.send(data);
}
</script>
</head>
<body>
<div id="myDiv">
<table width="100%" cellpadding="3" cellspacing="0">
<tbody>
<tr>
<td width="34%">
<div align="right">
<strong>First Name: </strong>
</div>
</td>
<td>
<div>
<input name="First_Name" type="text"id="First_Name" size="20">
</div>
</td>
</tr>
<tr>
<td>
<div align="right">
<strong>Last Name: </strong>
</div>
</td>
<td>
<input name="Last_Name" type="text" id="Last_Name" size="20">
</td>
</tr>
</tbody>
</table>
<div align="center">
<input id="button" type="button" value="Update Student Details" onclick="runAjax();" style="margin:5px;">
</div>
</div>
</body>
</html>
在除 IE10 之外的所有浏览器中,此操作均能正常工作。Fiddler 显示 IE 收到 401 响应。
请求标头 提琴手
POST http://dev.mysite/service/name/service.aspx/ChangeName HTTP/1.1
Accept: */*
Content-Type: application/json; charset=utf-8
Referer: http://dev.mysite/test_page.html
Accept-Language: en-US
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)
Connection: Keep-Alive
Content-Length: 46
DNT: 1
Host: dev.mysite
Pragma: no-cache
{"ID":"2","firstName":"John","lastName":"Doe"}
响应标头 提琴手
HTTP/1.1 401 Unauthorized
Content-Type: application/json; charset=utf-8
Server: Microsoft-IIS/7.0
jsonerror: true
WWW-Authenticate: Negotiate
WWW-Authenticate: NTLM
X-Powered-By: ASP.NET
Date: Thu, 07 Mar 2013 01:12:05 GMT
Content-Length: 105
Proxy-Support: Session-Based-Authentication
我在服务器上启用了失败请求跟踪,这是它为我提供的该调用的信息:
失败请求日志 互联网信息服务
1.-GENERAL_REQUEST_START 复制代码
- 站点编号- 2
- 应用程序池ID- ASP.NET v4.0
- 连接号- 1610622306
- 原始连接标识符- 0
- 请求URL-http://dev.mysite:80/service/name/service.aspx/ChangeName
- 请求动词- 邮政
2.-FILTER_START
- 过滤器名称- C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_filter.dll
3.-FILTER_END
4.-AspNetStart
- 连接号- 0
- 上下文 ID- {00000000-0000-0000-6425-0080000000BF}
- 数据1- 邮政
- 数据2- /服务/名称/服务.aspx
- 数据3-
5.-一般请求结束
- 已发送字节数- 359
- 已接收字节数- 440
- Http状态- 401
- HttpSubStatus- 0
通过简化 ajax 请求我发现,这不仅是 Windows 8 的问题,而且打开兼容模式也不起作用。
我尝试过禁用 IIS 中的内核模式身份验证,并三次检查了 Web 服务文件夹的权限,遵循这些建议,我甚至尝试将 Web 服务放在与页面相同的目录中。所有结果都相同。任何指导或帮助都将不胜感激。