.Net Mvc-导出PDF-思路方案

2024-09-08 01:48
文章标签 导出 pdf mvc net 方案 思路

本文主要是介绍.Net Mvc-导出PDF-思路方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果图:


导语:
    在我们做项目的过程中,经常会遇到一些服务性的需求,感到特别困扰,明明实用的价值不高,但是还是得实现;
    因此小客在这里整理一下自己导出PDF的一些思路,供大家参考。
    网上有很多导出PDF运用到的插件,大家也可以看看其他插件的使用,学习学习;

提要:
    这里我使用的是-iTextSharp,供大家参考参考,借鉴方案,完善思路,补充自己,一起学习;

准备工作:
    1、在自己的项目解决方案中---工具->Nuget程序管理包->程序管理控制台,安装iTextSharp插件;
    Install-Package iTextSharp
    Install-Package itextsharp.xmlworker

开始实现:
    1、首先创建一个文档,便于后续toPdf
        Document document = new Document(PageSize.A4, 5, 5, 20, 20);
    2、定义好我们需要存储的路径
        string path =  Server.MapPath(@"..\Common\ExportWord\" + "xxxxxxxxxxx.pdf");
        相对路径,Common\ExportWord 这两个文件夹必须是真实存在的;
    3、根据存储的路径来创建文件流
        FileStream fsPath = new FileStream(path, System.IO.FileMode.Create);
    4、将文件流和新建的文档 放入PdfWriter中直接创建PDF格式的文件
        PdfWriter writer = PdfWriter.GetInstance(document, fsPath);
    5、创建字体样式,便于后面使用
        BaseFont bfChinese = BaseFont.CreateFont(@"C:\WINDOWS\Fonts\simsun.ttc,1", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
        //表格标题--字体设置
        Font fontRukuHeader = new Font(bfChinese, 15, Font.NORMAL, BaseColor.BLACK);
        //表格第一行标头--字体设置
        Font fontTtitle = new Font(bfChinese, 10, Font.NORMAL, BaseColor.BLACK);
        //表格数据--字体设置
        Font fontGrid = new Font(bfChinese, 10);
    6、打开文档,按照导出的需求模板来开始填充文档信息数据,
        document.Open();
    7、设置整个表格的总列数
        PdfPTable table = new PdfPTable(7);
    8、开始调整模板,根据你的需求来调整
        PdfPCell firstCell = new PdfPCell(new Phrase("内部确认单", fontRukuHeader));
        firstCell.Colspan = 7;//合并7行
        firstCell.HorizontalAlignment = PdfPCell.ALIGN_CENTER;//居中
        firstCell.PaddingBottom = 6;
        table.AddCell(firstCell);
    9、将表格数据放入文档中
        document.Close();
        document.Add(table);
    10、输出成PDF
        PdfReader reader = new PdfReader(path);
        MemoryStream stream = new MemoryStream();
        PdfStamper pdfstamper = new PdfStamper(reader, stream);
        pdfstamper.FormFlattening = true;
        pdfstamper.Close();
        reader.Close();
        Byte[] btArray = stream.ToArray();
        FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write);
        fs.Write(btArray, 0, btArray.Length);
        fs.Flush();
        fs.Close();
        FileInfo downloadFile = new FileInfo(path);
        string name = Path.GetFileName(path);
        return File(path, 'application/pdf', Url.Encode(name));
        
        
        

这篇关于.Net Mvc-导出PDF-思路方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146772

相关文章

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

使用Python实现批量分割PDF文件

《使用Python实现批量分割PDF文件》这篇文章主要为大家详细介绍了如何使用Python进行批量分割PDF文件功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、架构设计二、代码实现三、批量分割PDF文件四、总结本文将介绍如何使用python进js行批量分割PDF文件的方法

使用Python实现PDF与SVG互转

《使用Python实现PDF与SVG互转》SVG(可缩放矢量图形)和PDF(便携式文档格式)是两种常见且广泛使用的文件格式,本文将详细介绍如何使用Python实现SVG和PDF之间的相互转... 目录使用工具使用python将SVG转换为PDF使用Python将SVG添加到现有PDF中使用Python将PD

Java导出Excel动态表头的示例详解

《Java导出Excel动态表头的示例详解》这篇文章主要为大家详细介绍了Java导出Excel动态表头的相关知识,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录前言一、效果展示二、代码实现1.固定头实体类2.动态头实现3.导出动态头前言本文只记录大致思路以及做法,代码不进

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一