我有一个控制台应用程序,它将 XML 发送到 MVC 应用程序并接收另一个 XML 作为响应。它工作得很好,但我想添加授权(出于显而易见的原因)。
这是来自控制台应用程序的代码:
using (var wc = new WebClient())
{
return GetXmlFromBytes(
wc.UploadData("URL", GetBytesFromXml(xmlToSend))
);
}
这是 MVC 应用程序的代码:
public ActionResult DoSomething()
{
XElement xml = XElement.Load(new System.IO.StreamReader(Request.InputStream));
var response = InsertDataFromXml(xml);
return File(GenerateFileFromResponse, "text/xml", "result.xml");
}
它有效。因此,为了实现授权,我添加了以下代码:
控制台(添加了wc.Credentials
):
using (var wc = new WebClient())
{
wc.Credentials = new NetworkCredential("user", "password");
return GetXmlFromBytes(
wc.UploadData("URL", GetBytesFromXml(xmlToSend))
);
}
MVC 应用程序(添加了[Authorize]
):
[Authorize]
public ActionResult DoSomething()
{
XElement xml = XElement.Load(new System.IO.StreamReader(Request.InputStream));
var response = InsertDataFromXml(xml);
return File(GenerateFileFromResponse, "text/xml", "result.xml");
}
它不起作用。我不知道是否需要此信息来解决此问题,但我web.config
有以下项目:
<authentication mode="Forms">
<forms loginUrl="~/Account/LogOn" timeout="2880" />
</authentication>
事实上,MVC 应用程序发回的文件就是 LogOn 页面的 HTML!
我该怎么做才能解决这个问题?中是否缺少任何参数NetworkCredentials
?我知道它可以用 实例化domain
,但我不知道 MVC 应用程序中用户的域是什么。
而且,只是为了确保:我保证“用户”和“密码”是有效的。