请求因 HTTP 状态 401 失败:Unauthorized。

时间:2023-01-23 13:49:32

 

 

“/TServiceWeb”应用程序中的服务器错误。

请求因 HTTP 状态 401 失败:Unauthorized。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Net.WebException: 请求因 HTTP 状态 401 失败:Unauthorized。

源错误:


源文件: F:\MyWorkRoom\DotNetProgram\TWebService\TServiceWeb\Web References\localhost\Reference.cs    行: 37

堆栈跟踪:



版本信息: Microsoft .NET Framework 版本:1.1.4322.2300; ASP.NET 版本:1.1.4322.2300


这个问题找了我很久,google上说都是权限的问题[客户端没有访问WebService的权限,于是将EveryOne设置为完全权限],可都没什么问题,然后在IIs中把匿名访问打勾就OK了,

 

 

 

 service.Credential   =   System.Net.CredentialCache.DefaultCredential  

System.Net.CredentialCache.DefaultCredentials:获取应用程序的系统凭据。

DefaultCredentials 属性仅适用于基于 NTLM、协商和 Kerberos 的身份验证。

DefaultCredentials 表示运行应用程序的当前安全上下文的系统凭据。对于客户端应用程序,这些通常是运行应用程序的用户的 Windows 凭据(用户名、密码和域)。对于 ASP.NET 应用程序,默认凭据是已登录的用户或正被模拟的用户的用户凭据。

若要获取作为 NetworkCredential 实例的凭据,请使用 DefaultNetworkCredentials 属性。

支持的 authType 值有“NTLM”、“Digest”、“Kerberos”和“Negotiate”。此方法对 HTTP 或 FTP 协议无效。

DefaultCredentials 返回的 ICredentials 实例不能用于查看当前安全上下文的用户名、密码或域。

例1

MRBService.MRBService service = new MRBService.MRBService();//service是Web Server的代理类名
 service.Credentials = System.Net.CredentialCache.DefaultCredentials;
也可以在webserver中属性Start options中选上NTLM Authentication,就不用写上面的代码了。
例2
string url = "http://localhost";
HttpWebRequest myHttpWebRequest = (HttpWebRequest)WebRequest.Create(url); myHttpWebRequest.Credentials = CredentialCache.DefaultCredentials;
HttpWebResponse myHttpWebResponse = (HttpWebResponse)myHttpWebRequest.GetResponse(); Console.WriteLine("Authentication successful");
Console.WriteLine("Response received successfully");