Estou perseguindo um problema e Decidi fazer a reprodução mais básica possível da questão na esperança de que uma pergunta simplificada me ajudasse a resolver isso.
Estou recebendo um erro 401 ao postar em um serviço da web via AJAX em JavaScript. Vou incluir o máximo de informações, bem como todas as etapas de solução de problemas que tentei.
Eu criei uma página de teste na raiz do meu site e tentei JS e jQuery simples para a chamada AJAX com os mesmos resultados. Eu incluí o jquery comentou:
Página:
<!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><scripttype="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>
Em todos os navegadores, exceto no IE10, isso funciona bem. O Fiddler mostra que o IE está recebendo uma resposta 401.
Solicitar cabeçalhos fiddler
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"}
Cabeçalhos de resposta fiddler
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
Eu ativei o Rastreamento de Solicitações Falhadas no servidor, e esta é a informação que me dá para essa chamada:
Log de solicitação com falha iis
1. -GENERAL_REQUEST_START
2. -FILTER_START
3. -FILTER_END
4. -AspNetStart
5. -GENERAL_REQUEST_END
Uma coisa que achei simplificando a solicitação do ajax foi que não é apenas um problema do Windows 8 e que a ativação do modo de compatibilidade também não funciona.
Eu tentei desativar a autenticação no modo kernel no IIS, verifiquei três vezes as permissões na pasta do serviço da Web, seguiu estas sugestões , e eu até tentei colocar o serviço web no mesmo diretório que a página. Todos produzem o mesmo resultado. Qualquer direção ou assistência seria muito apreciada.