8

我有一个报告服务服务器,它已经有一些正在运行的报告,我现在需要通过自定义网站(运行 asp.net MVC3)生成它们。

我需要将此报告作为流/字节检索以将其发送给用户。没有“报告查看器”左右。

我上次使用报告服务是使用 sql 2005,我们应该将一个不起眼的 asmx 文件作为参考。

现在情况如何,使用 sql server 报告 2008 R2、.Net4 和 Visual Studio 2010?我找不到解释整个事情的教程。

(实际上我找不到没有 sql 2008 r2 报告查看器的教程)

4

2 回答 2

17

MSDN提供了几种方法。我经常使用URL 访问来获取 ASP .NET 应用程序中的快速简单 PDF 按钮。

这是执行此操作的快速破解代码。可以清理它以使用集成身份验证,并且可以通过多种方式存储报告名称。(我从一些旧代码中剪切并粘贴了它,这些代码会将报告存储到数据库中,然后可以从数据库中返回它。

// First read in the report into memory.

string strReportUser = "RSUserName";
string strReportUserPW = "MySecretPassword";
string strReportUserDomain = "DomainName";

string sTargetURL = "http://SqlServer/ReportServer?" +
   "/MyReportFolder/Report1&rs:Command=Render&rs:format=PDF&ReportParam=" +
   ParamValue;

HttpWebRequest req =
      (HttpWebRequest)WebRequest.Create( sTargetURL );
req.PreAuthenticate = true;
req.Credentials = new System.Net.NetworkCredential(
    strReportUser,
    strReportUserPW,
    strReportUserDomain );

HttpWebResponse HttpWResp = (HttpWebResponse)req.GetResponse();

Stream fStream = HttpWResp.GetResponseStream();




//Now turn around and send this as the response..
byte[] fileBytes = ReadFully( fStream );
// Could save to a database or file here as well.

Response.Clear();
Response.ContentType = "application/pdf";
Response.AddHeader(
    "content-disposition",
    "attachment; filename=\"Report For " +
        ParamValue + ".pdf\"" );
Response.BinaryWrite( fileBytes );
Response.Flush();
HttpWResp.Close();
Response.End();

ReadFully 是

public static byte[] ReadFully( Stream input )
{
   using ( MemoryStream ms = new MemoryStream() )
   {
      input.CopyTo( ms );
      return ms.ToArray();
   }
}  
于 2012-06-05T15:57:25.833 回答
0

因为您有嵌套流,所以您可能希望在复制后关闭第一个流以避免关闭流错误。此外,如果您收到 401 Unauthorized,请尝试使用默认凭据。

            req.UseDefaultCredentials = true;
            req.PreAuthenticate = true;
            req.Credentials = CredentialCache.DefaultCredentials;

            HttpWebResponse HttpWResp = (HttpWebResponse)req.GetResponse();

            Stream fStream = HttpWResp.GetResponseStream();                

            //Now turn around and send this as the response..
            byte[] fileBytes = ReadFully(fStream);
            // Could save to a database or file here as well.
            HttpWResp.Close();
于 2015-06-04T09:36:49.133 回答