CrystalDecisions.Shared.CrystalReportsException:加载报告失败。该文档尚未打开

问题描述 投票:1回答:1

我有方法,我正在使用晶体决策报告,并且抛出内部异常。如何解决此问题?我见过类似的话题,但是我的尝试并没有真正解决类似的问题。请在下面查看我的逻辑和屏幕截图,以获取更多详细信息。换句话说,我的加载方法无法打开。

// Controller
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult AdvertReport(FormCollection fc)
{
    DataSet ds = obIlReports.Generate_AdvertDetailsReport();
    ds.Tables[0].TableName = "Tbl_TrainingAcademy";

    if(ds.Tables[0].Rows.Count > 0)
    {
        ReportClass rptH = new ReportClass();
        rptH.FileName = Server.MapPath("~/Reports/AdvertReport.rpt");
        rptH.Load(); // The document do not open error is thrown here.
        rptH.SetDataSource(ds.Tables[0]);
        Response.Buffer = false;
        Response.ClearContent();
        Response.ClearHeaders();


        Stream stream = rptH.ExportToStream(CrystalDecisions.Shared.ExportFormatType.PortableDocFormat);
        stream.Seek(0, SeekOrigin.Begin);
        return File(stream, "application/pdf", "AdvertReport.pdf");
    }
    return View();
}
// Ilreport here with store procedure.
public class ReportsMaster : IlReports
{
    public DataSet Generate_AdvertDetailsReport()
    {
        using(SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["eNtsaOnlineRegistrationDB"].ToString()))
        {
            con.Open();
            DataSet ds = new DataSet();

            // Handling Exception
            try
            {
                SqlCommand cmd = new SqlCommand("dbo.GetAdvertReport", con);
                cmd.CommandType = CommandType.StoredProcedure;
                SqlDataAdapter da = new SqlDataAdapter();
                da.SelectCommand = cmd;
                da.Fill(ds);

                if(ds.Tables.Count > 0)
                {
                    return ds;
                }
                else
                {
                    return ds = null;
                }

            }
            catch(Exception )
            {
                throw;
            }
            finally
            {
                ds.Dispose();
            }
        }
    }
}
// ConnectionString
<connectionStrings>
    <add name="eNtsaOnlineRegistrationDB" connectionString="Data Source=GcobaniM-L\SQLEXPRESS; DataBase=eNtsaOnlineRegistrationDB; Integrated Security=True" providerName="System.Data.SqlClient" />
</connectionStrings>
c# sql-server asp.net-mvc
1个回答
0
投票
  1. 我遇到的问题很简单,我创建报告文件时没有为Microsoft Visual Studio安装像Crystal报表这样的扩展报告。这是Windows的兼容性链接。

https://www.sap.com/cmp/td/sap-crystal-reports-visual-studio-trial.html?trial=%2F%2Fwww.sap.com%2Fregistration%2Ftrial.9a4afb3b-7eaa-42af-98ce-abeae5deb784.html

  1. 安装此软件后,Visual Studio将具有报告功能。请参阅我的屏幕截图,以获取想法或线索。enter image description here

  2. 确保在完成软件之前关闭VS。

  3. 然后您创建报告并根据您的项目应用程序给出其路径。

  4. 如果您遇到类似下面的异常;

Could not load file or assembly CrystalDecisions.CrystalReports.Engine

  1. 如果没有解决问题,请按照论坛中提到的步骤操作,并且您的应用程序应该可以运行。
© www.soinside.com 2019 - 2024. All rights reserved.