I am attempting to add a Crystal Report Viewer to an asp.net web app. We are using reports that were created for our desktop application so they are already created and functional. We are connecting to the same database with the same query across both platforms and the database and query is set up in the report designer.
Here's a preview from one of the reports in Visual Studio Pro 2015 in the asp.net project:
I have added the following line to my Reports.aspx page:
<CR:CrystalReportViewer ID="crptViewer" runat="server" AutoDataBind="true" />
I added a "Crystalreportviewers13" folder to the root of the application directory with the content of crystal report installation.
I have added the following to my web.config file:
<configuration>
<configSections>
<sectionGroup name="businessObjects">
<sectionGroup name="crystalReports">
<section name="rptBuildProvider" type="CrystalDecisions.Shared.RptBuildProviderHandler, CrystalDecisions.Shared, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304, Custom=null"/>
<section name="crystalReportViewer" type="System.Configuration.NameValueSectionHandler"/>
</sectionGroup>
</sectionGroup>
</configSections>
<businessObjects>
<crystalReports>
<rptBuildProvider>
<add embedRptInResource="true"/>
</rptBuildProvider>
<crystalReportViewer>
<add key="ResourceUri" value="/crystalreportviewers13" />
</crystalReportViewer>
</crystalReports>
</businessObjects>
I have tried several strategies on the code behind based on different stack overflow suggestions. Here's what I've tried so far:
On Button Click:
public partial class Reports : System.Web.UI.Page
{
ReportDocument rptDocument;
protected void Page_Load(object sender, EventArgs e)
{
string stack = "Page_Load()(Reports.aspx.cs)";
try
{
if (Session["report"] != null)
{
crptViewer.ReportSource = Session["report"];
}
}
catch (Exception EX)
{
IOClass.appendLog("Error in " + stack, EX.Message);
}
}
//Button Click
protected void generateReport(object sender, EventArgs e)
{
rptDocument = new ReportDocument();
rptDocument.Load(Server.MapPath("~/Crystal/UserListing.rpt"));
rptDocument.SetParameterValue("Company", 1);
Session["report"] = rptDocument;
}
}
and On Load:
public partial class Reports : System.Web.UI.Page
{
ReportDocument rptDocument;
protected void Page_Load(object sender, EventArgs e)
{
string stack = "Page_Load()(Reports.aspx.cs)";
try
{
rptDocument = new ReportDocument();
rptDocument.Load(Server.MapPath("~\\Crystal\\UserListing.rpt"));
crptViewer.ReportSource = rptDocument;
//I have tried with and without the following:
//crptViewer.DataBind();
//and
//crptViewer.RefreshReport();
}
catch (Exception EX)
{
IOClass.appendLog("Error in " + stack, EX.Message);
}
}
}
When the page loads in both cases this is what I get:
I'm doing exception logging on the load function and I do not get any exceptions.
Any ideas what I'm doing wrong here? Let me know if I can provide any other information.
Thank you for your time