我使用HttpWebRequest以PDF格式以编程方式导出SSRS 2008报告。然而,我的问题是我的NetworkCredentials似乎无法正常工作。我在尝试访问SSRS时收到了未授权(401)错误。
我知道我提供的NetworkCredentials是正确的。如果我手动登录我们的SSRS Web服务,这些是我使用的确切凭据。此外,这在本地工作正常,而不是在我们的服务器上。
该报告在我们的asp.net 4.0网站上运行。当用户点击"生成报告"按钮,执行以下代码(错误发生在我的第二行,在WebRequest.Create上)以尝试连接到我的SSRS 2008:
string sTargetURL = "MY_REPORT_SERVER?/REPORT_NAME&rs:format=pdf&rs:command=render&rc:parameters=Collapsed";
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(sTargetURL);
req.PreAuthenticate = true;
req.Credentials = new NetworkCredential("Username", "Password", "Domain");
HttpWebResponse HttpWResp = (HttpWebResponse)req.GetResponse();
Stream fStream = HttpWResp.GetResponseStream();
byte[] fileBytes = ReadFully(fStream);
HttpWResp.Close();
System.Web.HttpContext.Current.Response.Clear();
System.Web.HttpContext.Current.Response.ContentType = "application/pdf";
System.Web.HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=\"" + reportName + ".pdf"\"");
System.Web.HttpContext.Current.Response.BinaryWrite(fileBytes);
System.Web.HttpContext.Current.Response.Flush();
System.Web.HttpContext.Current.Response.End();
答案 0 :(得分:0)
在应用程序之外,您是否可以在本地和报表管理器/服务器中运行报表?如果是,报告使用什么类型的数据源?可能是数据源不接受从报表服务器双跳的凭据。您可能需要创建具有必要读取权限的域帐户,并在报表服务器上配置数据源以模拟这些凭据。