我有一个 Intranet 站点,它从另一个服务器(也在 Intranet 上)调用 POST 方法。
如果我在 IIS 中将身份验证模式设置为基本身份验证,我可以使用以下内容:
HttpWebRequest oReq = (HttpWebRequest)WebRequest.Create(sURL);
oReq.ContentType = "application/x-www-form-urlencoded";
oReq.Method = "POST";
oReq.Timeout = 60000;
...
oReq.Credentials = System.Net.CredentialCache.DefaultNetworkCredentials;
...
try
{
HttpWebResponse oResp = (HttpWebResponse)oReq.GetResponse();
...
}
以上所有工作都按预期工作。
但是,我需要在 IIS 中将安全性更改为 Windows 身份验证,一旦这样做,我就会在此行不断收到错误 401 未经授权:
try
{
HttpWebResponse oResp = (HttpWebResponse)oReq.GetResponse();
...
}
这可以通过更改凭据来解决,如下所示:
NetworkCredential creds = new NetworkCredential("username","password","domain");
oReq.Credentials = creds;
但这无论如何都不是正确的方法。如何获得默认凭据以也适用于 Windows 身份验证?