【发布时间】:2013-04-29 17:58:00
【问题描述】:
嗯,我已经尝试了很多方法来解决这个问题,但都没有。
我开发了一个报告服务 (2005) 并进行了部署。
这个报告将被每个访问在框架3.5上开发的网站(它是一个互联网站点,所以不会被内网访问)的人使用(但我认为框架的版本不是问题的根源) .
当用户单击按钮下载报告自动生成的 .pdf 文件时(最终用户永远不会看到报告的 html 版本),它会要求提供 Windows 凭据。
如果用户输入一个有效的凭证(并且这个凭证必须是部署报告服务的服务器上的一个有效凭证),那么 .pdf 显然会被下载。
但这不可能发生。最终用户必须直接下载 .pdf,而不要求提供凭据。毕竟他连证件都没有。
Response.Redirect("http://MyServer/ReportServer/Pages/ReportViewer.aspx?%2fReportLuiza%2fReportContract&rs:Format=PDF&NMB_CONTRACT=" + txtNmbContractReport.Text);
上面的代码 sn-p,当用户单击按钮时显示我的代码的第一个版本。这是 Windows 凭据的提示。
我已经尝试在 IIS 上更改虚拟目录 ReportServer 的身份验证,但唯一有效的是 Windows 凭据。其他的甚至不让我打开报表的虚拟目录或报表管理器的虚拟目录。
当我尝试将其更改为 匿名身份验证时,他无法访问数据库。然后我选择安全存储在报表服务器上的凭据选项。还是不行。
我的 ReportServer 虚拟目录的物理目录指向硬盘上的报告服务器文件夹 (C:\Program Files\Microsoft SQL Server\MSSQL.5\Reporting Services\ReportServer)。我将同一个文件夹移动到我的 wwwroot 目录。 没用。虚拟目录甚至没有打开。然后我读到这可能是一个问题,因为我在两个文件夹中有相同的名称(一个在 C: 中,另一个在 wwwroot 中)。所以我在wwwroot中更改了一个名称。无法完成数据库连接的相同问题。 我返回了 C 的物理路径:
下面是我的按钮事件代码的第二个版本:
ReportExecutionService rs = new ReportExecutionService();
rs.Credentials = System.Net.CredentialCache.DefaultCredentials;
rs.Url = "http://MyServer/ReportServer/ReportExecution2005.asmx";
// Render arguments
byte[] result = null;
string reportPath = "/ReportLuiza/ReportContract";
string format = "PDF";
// Prepare report parameter.
ParameterValue[] parameters = new ParameterValue[1];
parameters[0] = new ParameterValue();
parameters[0].Name = "NMB_CONTRACT";
parameters[0].Value = txtNmbContractReport.Text;
string encoding;
string mimeType;
string extension;
Warning[] warnings = null;
string[] streamIDs = null;
ExecutionInfo execInfo = new ExecutionInfo();
ExecutionHeader execHeader = new ExecutionHeader();
rs.ExecutionHeaderValue = execHeader;
execInfo = rs.LoadReport(reportPath, null);
rs.SetExecutionParameters(parameters, "pt-br");
String SessionId = rs.ExecutionHeaderValue.ExecutionID;
try
{
result = rs.Render(format, null, out extension, out encoding, out mimeType, out warnings, out streamIDs);
execInfo = rs.GetExecutionInfo();
}
catch (SoapException se)
{
ShowMessage(se.Detail.OuterXml);
}
// Write the contents of the report to an pdf file.
try
{
using (FileStream stream = new FileStream(@"c:\report.pdf", FileMode.Create, FileAccess.ReadWrite))
{
stream.Write(result, 0, result.Length);
stream.Close();
}
}
catch (Exception ex)
{
ShowMessage(ex.Message);
}
对于这段代码,我必须在其中提到的 .asmx 文件中添加一个 WebReference。
当我调试时(在 Visual Studio 2010 上),上面的代码工作正常,不要求提供凭据(不幸的是,它没有提示打开、保存或取消文件下载的选项。但这是另一个问题,现在不用担心)并将文件保存在 C:.
发布后,代码不起作用。错误提示:授予用户 'IIS APPPOOL\ASP.NET v4.0' 的权限不足以执行此操作。所以我在 Reporting Service 的用户中添加了这个用户。当我再次尝试时,错误是:用户 IISAPPPOOL\ASP.NET v4.0 登录失败。无法创建与数据源“MyDataSourceName”的连接。
报表和网站都部署/发布在具有 IIS 7.5 版本的同一台服务器上。
总结:我需要一个没有凭据提示的解决方案,用户可以选择保存.pdf文件的位置。
任何帮助将不胜感激。
如果您需要更多信息来帮助我,请尽管询问。
提前致谢。
【问题讨论】:
标签: asp.net .net-3.5 iis-7.5 reportingservices-2005