私は問題を追跡してきましたが、簡単な質問がこれを解決するのに役立つことを期待して、問題の最も基本的な再現を可能にすることにしました。
javascriptのajaxを介してWebサービスに投稿するときに401を受け取ります。私が試したすべてのトラブルシューティング手順だけでなく、できるだけ多くの情報を含めます。
私は自分のサイトのルートにテストページを作成し、ajax呼び出しに対してプレーンJSとjqueryの両方を試しましたが同じ結果になりました。コメントアウトされた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を除くすべてのブラウザで、これは正常に機能します。フィドラーでは、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
サーバーでFailedRequestTracingを有効にしました。これは、その呼び出しに対して提供される情報です。
失敗した要求ログ iis
1. -GENERAL_REQUEST_START
- SiteId -2
- AppPoolId-ASP.NET v4.0
- ConnId -1610622306
- RawConnId -0
- RequestURL - http://dev.mysite:80/service/name/service.aspx/ChangeName
- RequestVerb -POST
2. -FILTER_START
- FilterName -C:\ Windows \ Microsoft.NET \ Framework \ v4.0.30319 \ aspnet_filter.dll
3. -FILTER_END
4. -AspNetStart
- ConnID -0
- コンテキストID-{00000000-0000-0000-6425-0080000000BF}
- データ1 - POST
- データ2- /service/name/ service.aspx
- データ3-
5. -GENERAL_REQUEST_END
- BytesSent -359
- BytesReceived -440
- HttpStatus -401
- HttpSubStatus -0
ajaxリクエストを単純化して見つけたのは、Windows 8の問題だけでなく、互換モードをオンにしても機能しないということでした。
IISでカーネルモード認証を無効にしてみました。Webサービスフォルダーのアクセス許可を3回確認し、次の提案に従いました。Webサービスをページと同じディレクトリに配置することも試みました。すべて同じ結果になります...どんな方向性や支援も大歓迎です。