概述
“/TServiceWeb”应用程序中的服务器错误。
请求因 HTTP 状态 401 失败:Unauthorized。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.Net.WebException: 请求因 HTTP 状态 401 失败:Unauthorized。
源错误:
源文件: F:MyWorkRoomDotNetProgramTWebServiceTServiceWebWeb ReferenceslocalhostReference.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");
转载于:https://www.cnblogs.com/pokay/archive/2009/04/30/1446789.html
最后
以上就是超帅朋友为你收集整理的请求因 HTTP 状态 401 失败:Unauthorized。“/TServiceWeb”应用程序中的服务器错误。 的全部内容,希望文章能够帮你解决请求因 HTTP 状态 401 失败:Unauthorized。“/TServiceWeb”应用程序中的服务器错误。 所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复