在2.2里程碑中咱們增長了一些新的功能,正如標題所寫經過請求頭進行導出咱們不一樣格式的文件.下面咱們來看一下如何使用.經過這種方式不管是對咱們的數據多用途,仍是說對咱們的數據校驗都作到了輕鬆易配。html
同時咱們也將在本週發佈2.3版本,另外3.0版本咱們將進行一次大的性能提高。3.0版本咱們將對Razor引擎以及導出引擎進行更換,包括對全部代碼的重構,這是值得期待的。git
上週咱們發佈了2.2.5版本更新以下:github
【Nuget】版本更新到2.2.5shell
【Excel導出】增長分欄、分sheet、追加rows導出 #74json
- exporter.Append(list1).SeparateByColumn().Append(list2).ExportAppendData(filePath); - exporter.Append(list1).SeparateBySheet().Append(list2).ExportAppendData(filePath); - exporter.Append(list1).SeparateByRow().AppendHeaders().Append(list2).ExportAppendData(filePath);
[Excel導出】修復‘IsAllowRepeat=true’ #107微信
[Pdf導出】增長PDF擴展方法,支持經過以參數形式傳遞特性參數 #104app
- Task<byte[]> ExportListBytesByTemplate<T>(ICollection<T> data, PdfExporterAttribute pdfExporterAttribute,string temple); - Task<byte[]> ExportBytesByTemplate<T>(T data, PdfExporterAttribute pdfExporterAttribute,string template);
Install-Package Magicodes.IE.AspNetCore
在Startup.cs
的Configure()方法中,在UseRouting()中間件以後,註冊以下中間件性能
public void Configure(IApplicationBuilder app) { app.UseRouting(); app.UseMagiCodesIE(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); }
上面這種以中間件形式能夠爲咱們提供導出服務,那麼咱們再看一下另外一種方式以下所示:微信支付
public void ConfigureServices(IServiceCollection services) { services.AddControllers(options=>options.Filters.Add(typeof(MagicodesFilter))); }
上面兩種方式均可覺得咱們提供導出服務,咱們只須要對咱們的控制器進行配置咱們的特性,在這邊呢 特性主要作的是一個標識做用,標識他的一些相關的內容數據,同時標識他能夠當成文件導出。ui
[HttpGet("excel")] [Magicodes(Type = typeof(ExportTestDataWithAttrs))] public List<ExportTestDataWithAttrs> Excel() { return GenFu.GenFu.ListOf<ExportTestDataWithAttrs>(100); }
上面代碼片斷中咱們標識這個類容許被導出。同時咱們須要經過Type指定咱們被導出類的類型。
這樣填寫完後咱們能夠經過對該地址的調用,可是注意咱們必需要添加請求頭以標識被導出的文件類型。若是不添加請求頭,那麼此處將返回的仍是json格式的數據。請求頭名稱爲Magicodes-Type
/// <summary> /// XLSX /// </summary> internal const string XLSXHttpContentMediaType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"; /// <summary> /// PDF /// </summary> internal const string PDFHttpContentMediaType = "application/pdf"; /// <summary> /// DOCX /// </summary> internal const string DOCXHttpContentMediaType = "application/vnd.openxmlformats-officedocument.wordprocessingml.document"; /// <summary> /// HTML /// </summary> internal const string HTMLHttpContentMediaType = "text/html";
若是說是模板導出word或者pdf甚至說html文件那麼咱們也是一樣的操做以下所示:
[HttpGet("Word")] [Magicodes(Type = typeof(ReceiptInfo), TemplatePath = ".//ExportTemplates//receipt.cshtml")] public ReceiptInfo Word() { return new ReceiptInfo { Amount = 22939.43M, Grade = "2019秋", IdNo = "43062619890622xxxx", Name = "張三", Payee = "湖南心萊信息科技有限公司", PaymentMethod = "微信支付", Profession = "運動訓練", Remark = "學費", TradeStatus = "已完成", TradeTime = DateTime.Now, UppercaseAmount = "貳萬貳仟玖佰叄拾玖圓肆角叄分", Code = "19071800001" }; }
咱們仍是須要對其指定Type,而後經過TemplatePath進行指定模板地址便可
一樣的咱們還能夠經過請求頭進行標識本次請求是不是文件格式導出。
[HttpGet("pdf")] [Magicodes(Type = typeof(BatchPortraitReceiptInfoInput), TemplatePath = ".//ExportTemplates//batchReceipt.cshtml")] public BatchPortraitReceiptInfoInput Pdf() { var input = new BatchPortraitReceiptInfoInput { Payee = "湖南心萊信息科技有限公司", SealUrl = @"", LogoUrl = @"", ReceiptInfoInputs = new List<BatchPortraitReceiptInfoDto>() }; for (var i = 0; i < 500; i++) input.ReceiptInfoInputs.Add(new BatchPortraitReceiptInfoDto { Amount = 22939.43M, Grade = "2019秋", IdNo = "43062619890622xxxx", Name = "張三", PaymentMethod = "微信支付", Profession = "運動訓練", Remark = "學費", TradeStatus = "已完成", TradeTime = DateTime.Now, UppercaseAmount = "貳萬貳仟玖佰叄拾玖圓肆角叄分", Code = "1907180000" + i }); return input; } [HttpGet("Html")] [Magicodes(Type = typeof(ReceiptInfo), TemplatePath = ".//ExportTemplates//receipt.cshtml")] public ReceiptInfo Html() { return new ReceiptInfo { Amount = 22939.43M, Grade = "2019秋", IdNo = "43062619890622xxxx", Name = "張三", Payee = "湖南心萊信息科技有限公司", PaymentMethod = "微信支付", Profession = "運動訓練", Remark = "學費", TradeStatus = "已完成", TradeTime = DateTime.Now, UppercaseAmount = "貳萬貳仟玖佰叄拾玖圓肆角叄分", Code = "19071800001" }; }