分享
 
 
 

CSharp Tips:应用程序访问集成Windows认证的站点

王朝system·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

问题

从事过Web Application的人都知道,在一个Web Site可以允许用户匿名访问,也可以禁止匿名强制要求认证才能够访问。

在IIS的Directory Property/Directory Security下可以看到匿名访问(Anonymous access)和认证访问(Authenticated access)的选项。在认证访问中又有多种方式:基本认证(Basic)、摘要认证(Digest),还有著名的Windows集成(Integrated Windows authentication,以前应该叫做Challenge/Response)。

当选择和认证访问的时候,如果没有经过认证,任何请求都会被服务器拒绝,返回401-Unauthenticated的错误。通过IE访问Web Site,浏览器会帮你做掉很多事情,特别是当选择Windows集成模式,而用户又是登录域的,对用户感觉完全透明。但是在应用程序中怎么才能够向一个要求认证访问的站点发送请求呢?这就是我们的问题所在。

原因

在DotNet下面我们通常采用System.Web.HttpWebRequest/HttpWebResponse来完成有关HTTP的操作,对于客户端来说比较重要的就是发送请求的HttpWebRequest。

普通情况下,我们创建一个请求:

oRequest = (System.Net.HttpWebRequest) WebRequest.Create(uri);

if (oRequest != null)

{

// send request

oRequest.ProtocolVersion = HttpVersion.Version11;

oRequest.Method = @"GET";

oResponse = (System.Net.HttpWebResponse) oRequest.GetResponse();

}

这段代码请求允许匿名访问的站点的时候没有任何问题,但是当站点关闭匿名访问的开关的时候,就会收到上面提到的401的错误。因为我们并没有指定访问该站点的用户ID。

解决

HttpWebRequest类中有一个属性Credentials,该属性就是用来存放认证信息的。

如果希望用当前登录用户的认证信息,可以这么赋值:

oRequest.Credentials = CredentialCache.DefaultCredentials;

CredentialCache.DefaultCredentials记录了应用程序当前运行上下文中的认证信息,但是你无法从中读取用户名、口令和登录域(都是空字符串),不过确确实实记录了当前登录用户的信息,这也是Windows的保护机制吧。

如果希望用一个指定用户的身份访问,那么就必须提供用户名,口令和域名:

oCredential = new NetworkCredential(sUser,sPwd,sDomain);

oRequest.Credentials = oCredential.GetCredential(new Uri(uri),String.Empty);

在GetCredential方法中可以指定认证方式,也就是“Basic”、“NTLM”之类。具体参数含义,参考MSDN。

完整的例子

oRequest = (System.Net.HttpWebRequest) WebRequest.Create(uri);

if (oRequest != null)

{

// send request

oRequest.ProtocolVersion = HttpVersion.Version11;

oRequest.Method = @"GET";

if (sUser != String.Empty)

{

oCredential = new NetworkCredential(sUser,sPwd,sDomain);

oRequest.Credentials = oCredential.GetCredential(new Uri(uri),String.Empty);

}

else

{

oRequest.Credentials = CredentialCache.DefaultCredentials;

}

oResponse = (System.Net.HttpWebResponse) oRequest.GetResponse();

}

这样只要当前登录用户或者你提供帐号和口令的用户通过任何,你就可以像普通情况下一样访问Web Site上的资源了。当然如果提供了错误的用户名或者口令的话,不要来找我。

DotNet下非常简单,就到这里。

IE做了点什么?

题外话,谈谈当访问一个需要认证的站点的时候,IE做了点什么。

当服务端选择集成Windows的认证模式时,用户通过IE请求被保护的资源,服务端返回一个401的错误码,以及一个WWWW-Authenticate的HTTP报头(Header)。IE收到这个Header之后,将当前用户名、机器名和域名传递给服务端,服务端继续回应一个401的错误码以及WWW-Authenticate的报头。这是IE换算Password再次发送给服务端,这个时候认证才算完成。

如果当前登录Windows的用户没有权限访问服务端的资源,IE就会弹出一个对话框,要求用户输入访问用户名、口令和域名,再次重复上述过程。如果用户三次输入错误的信息,那么IE也玩不动了,直接告诉你“未经授权”。

可见IE还是做了很多事情的。如果我们要写一个比较好的客户端程序,也需要重复考虑这些问题。

参考文档

A、HttpWebRequest Class(http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemNetHttpWebRequestClassTopic.asp

B、CredentialCache Class(http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemNetCredentialCacheClassTopic.asp

C、NetworkCredenti Class(http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemNetNetworkCredentialClassTopic.asp

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有