“/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");