文档半岛外围网上直营>>FastReport.Net教程2020(持续更新中)>>FastReport.Net中文教程:如何将选项列表传输到Web报表
FastReport.Net中文教程:如何将选项列表传输到Web报表
创建报表时,通常需要从外部传输一些值。这是为了将数据过滤到报表中,或管理报表的逻辑。在使用FastReport.Net的实践中,我经常遇到这种需求。由于我主要使用Web报表,因此我通过url将参数传递到报表中。通常,我的报表非常复杂,并且不仅限于一个参数。因此,需要传递参数列表,即key值集列表。key是设置的名称。
下面我们可以一起实践操作一下。在这种情况下,我使用ASP. Ne Core Web Api应用程序。
namespace ParametersWeb.Models
{
public class Reports
{
// Report ID
public int Id { get; set; }
// Report File Name
public string ReportName { get; set; }
}
}
ValuesController:
填写报表数组:
Reports[] reportItems = new Reports[]
{
new Reports { Id = 1, ReportName = "Parameters.frx" },
new Reports { Id = 2, ReportName = "Master-Detail.frx" }
};
报表的生成方法是异步的,因为它使用异步方法将html格式的报表转换。如您所知,这种格式我们希望在浏览器中显示报表:
[HttpGet("{id}")]
public async System.Threading.Tasks.TaskGetAsync(int id)
{
string mime = "application/html"; // MIME header with default value
// Find report
var parameters = HttpContext.Request.QueryString.ToString().Substring(1);
Reports reportItem = reportItems.FirstOrDefault((p) => p.Id == id); // we get the value of the collection by id
if (reportItem != null)
{
string webRootPath = _hostingEnvironment.WebRootPath; // determine the path to the wwwroot folder
string reportPath = (webRootPath + "/App_Data/" + reportItem.ReportName); // determine the path to the report
string dataPath = (webRootPath + "/App_Data/nwind.xml");// determine the path to the database
using (MemoryStream stream = new MemoryStream()) // Create a stream for the report
{
try
{
using (DataSet dataSet = new DataSet())
{
// Fill the source by data
dataSet.ReadXml(dataPath);
// Turn on web mode FastReport
Config.WebMode = true;
WebReport webReport = new WebReport();//create the report object
webReport.Report.Load(reportPath); //upload the report
webReport.Report.RegisterData(dataSet, "NorthWind"); //register the data sourcw in the report
if (parameters != null)
{
string[] parameterList = parameters.Split(',');
foreach (string item in parameterList)
{
string[] parameter = item.Split('=');
webReport.Report.SetParameterValue(parameter[0], parameter[1]); //set the report parameter value
}
}
// inline registration of FastReport javascript
webReport.Inline = true;//allow to register scripts and styles in HTML-body intead of putting them in the header
HtmlString reportHtml = await webReport.Render(); //upload the report in HTML
byte[] streamArray = Encoding.UTF8.GetBytes(reportHtml.ToString());
stream.Write(streamArray, 0, streamArray.Length);//write down the report in the stream
}
// Get the name of the resulting report file with the necessary extension
var file = String.Concat(Path.GetFileNameWithoutExtension(reportPath), ".", "html");
return File(stream.ToArray(), mime, file); // attachment
}
// Handle exceptions
catch
{
return new NoContentResult();
}
finally
{
stream.Dispose();
}
}
}
else
return NotFound();
}
此方法的逻辑本质如下:我们上传选定的报表模板,从url解析参数并将其值传输到报表。然后,我们以html格式转换报表,然后将文件返回给客户端。
您传递给报表的参数名称应与报表中的参数明确匹配:


扫码立即申请

QQ交谈
在线咨询

渝公网安备
50010702500608号

客服热线