文档章节

FastReport教程:如何从.Net Core应用程序中的数据库向Email发送报表

x
 xiaochuachua
发布于 03/21 13:19
字数 1527
阅读 43
收藏 0

下载FastReport.Net最新版本

我们已经讨论过如何将报表发送到数据库中的一组电子邮件。在本文中,我们将做同样的事情,但对于.Net Core MVC平台上的Web应用程序。我们的任务是从某个数据库中获取电子邮件地址和用户名列表,并将带有附加报表的电子邮件发送到这些邮箱。我们使用MS SQL Server数据库。

FastReport

创建一个ASP应用程序.Net Core MVC应用程序。首先,使用NuGet Packages Manager将必要的库添加到项目中。在一般的nuget存储库中,我们找到并安装包:

  • Microsoft.EntityFrameworkCore;
  • Microsoft.EntityFrameworkCore.Relational;
  • Microsoft.jQuery.Unobtrusive.Ajax;
  • jQuery.

从本地存储库 - FastReport.Net安装目录中的Nuget文件夹,安装软件包:

  • FastReport.Core;
  • FastReport.Web.

现在我们将使用数据库和表的类本质创建工作上下文。为此,请打开包控制台Nuget。打开Tools - > Nuget Package Manager - >Package Manager Console menu(包管理器控制台菜单)。在控制台中,键入以下命令:

Server=localhost;Database=testdb;Trusted_Connection=True;

Microsoft.EntityFrameworkCore.SqlServer -OutputDir模型 当然,在这里您必须指定数据库服务器的连接字符串和数据模型的文件夹(默认情况下为Models)。

PM> scaffold-dbcontext“Server = localhost; Database = testdb; Trusted_Connection = True;”

Microsoft.EntityFrameworkCore.SqlServer -OutputDir模型 之后,理论上,应该将两个文件添加到Models文件夹:context和table实体。在我的例子中,这是testdbContext.cs和Emails.cs。 但是,在文件生成期间可能会发生错误:

错误MSB4064:“Csc”任务不支持“SharedCompilationId”参数。

有一个可设置的公共实例属性。 如果发生这种情况,请在NuGet包管理器中再添加一个包:

Microsoft.Net.Compillers

让我们马上将FastReport连接到我们的项目。在Startup.cs文件中,添加以下行:

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
 {
…
 app.UseFastReport();
…
}

现在回到数据模型。要从数据库中获取记录,我们需要创建GetEmails方法。创建用于处理数据的类Facade:

namespace WebMailing.Models
{
 public static class Facade
 {
 public static List<Emails> GetEmails()
 {
 using (Models.testdbContext context = new Models.testdbContext())
 {
 var emails = (from adresses in context.Emails
 select adresses).ToList();
 return emails;
 }
 }
 }
}

我们来看看'HomeController'控制器吧。在Index方法中,加载报表以在站点的主页上显示它:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using Microsoft.AspNetCore.Mvc;
using WebMailing.Models;
using FastReport;
using FastReport.Export.Pdf;
using FastReport.Export.Email;
using FastReport.Web;
…
public IActionResult Index()
{
 WebReport webReport = new WebReport();
 webReport.Report.Load(Environment.CurrentDirectory + "/text.frx");
 ViewBag.WebReport = webReport;
 return View();
}

我们将添加两种发送电子邮件的方法。第一个将在问候语中发送带有客户名称的私人信件,第二个将向一组地址发送一个字母。 所以,第一种方法是:

[HttpPost]
 public ActionResult SendMail()
 {
 Report report1 = new Report(); //Create new report object
 report1.Load(Environment.CurrentDirectory + "/text.frx"); //Load report
 report1.Prepare(); //Prepare report
 
 PDFExport pdf = new PDFExport(); //Cteate PDF export
 EmailExport email = new EmailExport(); //Create Email export
 
 List<Emails> emails = Models.Facade.GetEmails();
 foreach (Emails item in emails)
 {
 SendMessage(report1, pdf, email, item.Email, item.Name);
 }
 return View();
 }

使用它,我们创建了一个报表,导出为PDF,导出到电子邮件。然后,在循环中,我们从表中获取记录并调用发送字母的方法。作为参数,我们传递报表对象,导出PDF,导出到电子邮件,电子邮件地址和客户端名称。以下是发送信件的方法:

public void SendMessage(Report report, PDFExport pdf, EmailExport email, string recipient, string custName)
 {
 string message = "This is test message.";
 email.Account.Address = "gromozekaster@yandex.ru";
 email.Account.Name = "Test User";
 email.Account.Host = "smtp.yandex.ru";
 email.Account.Port = 25;
 email.Account.UserName = "Gromozekaster";
 email.Account.Password = "*****"; //Your password
 email.Account.MessageTemplate = "Test";
 email.Account.EnableSSL = true;
 //email addressee settings
 email.Address = recipient;
 email.Subject = "TestMessage";
 email.MessageBody = custName is null ? message : string.Format("Dear, {0}! {1}", custName, message);
 email.Export = pdf; //Set export type
 email.SendEmail(report); //Send email
 }

在其中,我们设置了一个电子邮件客户端来发送信件。并立即添加第二种方法,将一个字母发送到一组地址:

[HttpPost]
 public ActionResult SendAll()
 {
 Report report1 = new Report(); //Create new report object
 report1.Load(Environment.CurrentDirectory + "/text.frx"); //Load report
 report1.Prepare(); //Prepare report
 PDFExport pdf = new PDFExport(); //Cteate PDF export
 EmailExport email = new EmailExport(); //Create Email export
 
 List<Emails> emails = Models.Facade.GetEmails();
 string addresses = "";
 foreach (Emails item in emails)
 {
 if (addresses == "")
 addresses = item.Email;
 else
 addresses = addresses + ", " + item.Email;
 }
 SendMessage(report1, pdf, email, addresses, null);
 return View();
 }

正如您所看到的,它与之前的方法非常相似,唯一的区别是在循环中我们收到所有电子邮件地址,并发送一次这封信。作为电子邮件参数,我们传递一个包含所有电子邮件地址的字符串变量,但我们不传递客户端名称。

对于SendMail()和SendAll()方法,我们需要创建相同名称的视图 - 视图。 他们的内容非常简单:

@{
 ViewBag.Message = "Report was sent";
}
@ViewBag.Message

我们只是告知发送。让我们转到Index.cshtml视图。在其中,我们需要添加两个按钮来使用不同的方法发送字母,以及显示报表:

@{
 ViewData["Title"] = "Home Page";
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.1/jquery.min.js"></script>
 <form action="SendMail" method="POST">
 <input type="button" id="SendPersonal" value="Send Personal Email">
 <input type="button" id="SendAll" value="Send Email to All">
 <div class="answer"/>
 </form>
 <script type="text/javascript">
 $('#SendPersonal').on("click", function () {
 $.ajax({
 type: 'POST', // dispatch method
 url: '@Url.Action("SendMail", "Home")', // path to handler
 dataType: 'text',
 success: function (data) {
 $(".answer").html(data); // upon successful receipt of the response from the server, we enter the data in the element with the class answer
 }
 });
 return false;
 })
 $('#SendAll').on("click", function () {
 $.ajax({
 type: 'POST', // dispatch method
 url: '@Url.Action("SendAll", "Home")', // path to handler
 dataType: 'text',
 success: function (data) {
 $(".answer").html(data); // upon successful receipt of the response from the server, we enter the data in the element with the class answer
 }
 });
 return false;
 })
 </script>
@await ViewBag.WebReport.Render()

要使用ajax jquery,我们添加了一个指向jquery.min.js脚本的链接。接下来,为每个表单添加一个带有两个按钮和两个脚本的表单。脚本非常简单 - 从控制器调用方法并返回结果视图。

最后 - 我们从Index方法推导出报表。让我们运行应用程序,看看我们的网页是什么样的:

FastReport

我们通过不同的方式发信:

FastReport

和:

FastReport

在第一种情况下,在信函的文本中,我们通过名称引用客户端,在第二种情况下,没有,就这样。

本文转载自:https://www.fast-report.com/en/blog/260/show/

x
粉丝 0
博文 225
码字总数 49214
作品 0
私信 提问
如何在ReactJS中使用FastReport Core Web Report

下载FastReport.Net最新版本 FastReport Core Web Report旨在与流行的.Net Core框架协同工作。由于与趋势网框架和Angular,React,Vue等库的兼容性,他获得了更多的人气。因此,许多FastRep...

xiaochuachua
05/20
8
0
FastReport产品介绍及免费下载地址

公司地址: 俄罗斯 公司网址: http://www.fast-report.com 详细信息: 由技术总监Alexander Tzyganenko创建于1998年,Fast Reports, Inc.开发了快速报表软件:应用程序、库和插件。 FastRe...

yidongkaifa
2014/10/13
96
0
带有"文本搜索"和"编辑"功能的MSWord-like报表预览报表生成控件FastReport VC

FastReport VCL是一款Delphi和C++Builder平台下,功能强大的报表生成控件,它能使用户的应用程序快速有效地产生报表控件, 提供了创建报表所需的所有工 具,包括报表引擎,报表设计工具,预览...

longboo
2014/06/20
320
0
2015年用户界面工具干货资源精选

| 更多干货资源请移步用户界面专题 | DevExpress 2015.1超详细更新说明文档中文版 历时两月吐血翻译整理的DevExpress 2015.1超详细更新说明文档 | 附PDF版下载地址>> DevExpress 15.2帮助文档...

百mumu
2015/12/25
293
0
报表工具FastReport.Net v2016.4正式发布!

更新内容: [Core] 为WebReport 和 HTML导出添加新的HtmlObject对象 为自定义数据处理添加Report.CustomCalc事件 修复报表脚本中不正确集成加载的问题 [Designer] 添加TextOutline编辑器 修复...

鸟栖沙岩
2016/09/19
125
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周一乱弹 —— 熟悉的味道,难道这就是恋爱的感觉

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @xiaoshiyue :好久没分享歌了分享张碧晨的单曲《今后我与自己流浪》 《今后我与自己流浪》- 张碧晨 手机党少年们想听歌,请使劲儿戳(这里)...

小小编辑
今天
293
9
SpringBoot中 集成 redisTemplate 对 Redis 的操作(二)

SpringBoot中 集成 redisTemplate 对 Redis 的操作(二) List 类型的操作 1、 向列表左侧添加数据 Long leftPush = redisTemplate.opsForList().leftPush("name", name); 2、 向列表右......

TcWong
今天
19
0
排序––快速排序(二)

根据排序––快速排序(一)的描述,现准备写一个快速排序的主体框架: 1、首先需要设置一个枢轴元素即setPivot(int i); 2、然后需要与枢轴元素进行比较即int comparePivot(int j); 3、最后...

FAT_mt
昨天
4
0
mysql概览

学习知识,首先要有一个总体的认识。以下为mysql概览 1-架构图 2-Detail csdn |简书 | 头条 | SegmentFault 思否 | 掘金 | 开源中国 |

程序员深夜写bug
昨天
11
0
golang微服务框架go-micro 入门笔记2.2 micro工具之微应用利器micro web

micro web micro 功能非常强大,本文将详细阐述micro web 命令行的功能 阅读本文前你可能需要进行如下知识储备 golang分布式微服务框架go-micro 入门笔记1:搭建go-micro环境, golang微服务框架...

非正式解决方案
昨天
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部