日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > vue >内容正文

vue

SpringBoot+Vue+Itext实现前端请求文件流的方式下载PDF

發(fā)布時(shí)間:2025/3/19 vue 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SpringBoot+Vue+Itext实现前端请求文件流的方式下载PDF 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

場景

SpringBoot加itext實(shí)現(xiàn)PDF導(dǎo)出:

SpringBoot加itext實(shí)現(xiàn)PDF導(dǎo)出_BADAO_LIUMANG_QIZHI的博客-CSDN博客

上面實(shí)現(xiàn)導(dǎo)出pdf的基礎(chǔ)上,怎樣結(jié)合前端Vue發(fā)送請求實(shí)現(xiàn)導(dǎo)出pdf。

注:

博客:
BADAO_LIUMANG_QIZHI的博客_霸道流氓氣質(zhì)_CSDN博客-C#,SpringBoot,架構(gòu)之路領(lǐng)域博主
關(guān)注公眾號
霸道的程序猿
獲取編程相關(guān)電子書、教程推送與免費(fèi)下載。

實(shí)現(xiàn)

1、搭建前后端分離的架構(gòu)

若依前后端分離版本地搭建開發(fā)環(huán)境并運(yùn)行項(xiàng)目的教程:

若依前后端分離版手把手教你本地搭建環(huán)境并運(yùn)行項(xiàng)目_BADAO_LIUMANG_QIZHI的博客-CSDN博客_若依前后端分離文檔

2、后臺引入Itext依賴

??????? <dependency><groupId>com.itextpdf</groupId><artifactId>itextpdf</artifactId><version>5.2.0</version></dependency><dependency><groupId>com.itextpdf</groupId><artifactId>itext-asian</artifactId><version>5.2.0</version></dependency>

3、新建Controller

package com.ruoyi.web.controller.system;import com.itextpdf.text.*; import com.itextpdf.text.pdf.*; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.system.domain.TwoZhuModel; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.OutputStream; import java.net.URLEncoder; import java.util.*; import java.util.List;@Controller @RequestMapping("/exportPdf") public class ExportPDFController extends BaseController {@RequestMapping("/getPdf")public void excelPdf(HttpServletRequest request, HttpServletResponse response) throws Exception {//設(shè)置響應(yīng)格式等response.setContentType("application/pdf");response.setHeader("Expires", "0");response.setHeader("Cache-Control", "must-revalidate, post-check=0, pre-check=0");response.setHeader("Pragma", "public");Map<String,Object> map = new HashMap<>();//設(shè)置紙張規(guī)格為A4紙Rectangle rect = new Rectangle(PageSize.A4);//創(chuàng)建文檔實(shí)例Document doc=new Document(rect);//添加中文字體BaseFont bfChinese=BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);//設(shè)置字體樣式Font textFont = new Font(bfChinese,11, Font.NORMAL); //正常//Font redTextFont = new Font(bfChinese,11,Font.NORMAL,Color.RED); //正常,紅色Font boldFont = new Font(bfChinese,11,Font.BOLD); //加粗//Font redBoldFont = new Font(bfChinese,11,Font.BOLD,Color.RED); //加粗,紅色Font firsetTitleFont = new Font(bfChinese,22,Font.BOLD); //一級標(biāo)題Font secondTitleFont = new Font(bfChinese,15,Font.BOLD, CMYKColor.BLUE); //二級標(biāo)題Font underlineFont = new Font(bfChinese,11,Font.UNDERLINE); //下劃線斜體//設(shè)置字體com.itextpdf.text.Font FontChinese24 = new com.itextpdf.text.Font(bfChinese, 24, com.itextpdf.text.Font.BOLD);com.itextpdf.text.Font FontChinese18 = new com.itextpdf.text.Font(bfChinese, 18, com.itextpdf.text.Font.BOLD);com.itextpdf.text.Font FontChinese16 = new com.itextpdf.text.Font(bfChinese, 16, com.itextpdf.text.Font.BOLD);com.itextpdf.text.Font FontChinese12 = new com.itextpdf.text.Font(bfChinese, 12, com.itextpdf.text.Font.NORMAL);com.itextpdf.text.Font FontChinese11Bold = new com.itextpdf.text.Font(bfChinese, 11, com.itextpdf.text.Font.BOLD);com.itextpdf.text.Font FontChinese11 = new com.itextpdf.text.Font(bfChinese, 11, com.itextpdf.text.Font.ITALIC);com.itextpdf.text.Font FontChinese11Normal = new com.itextpdf.text.Font(bfChinese, 11, com.itextpdf.text.Font.NORMAL);//設(shè)置要導(dǎo)出的pdf的標(biāo)題String title = "霸道流氓氣質(zhì)";response.setHeader("Content-disposition","attachment; filename=".concat(String.valueOf(URLEncoder.encode(title + ".pdf", "UTF-8"))));OutputStream out = response.getOutputStream();PdfWriter.getInstance(doc,out);doc.open();doc.newPage();//新建段落//使用二級標(biāo)題 顏色為藍(lán)色Paragraph p1 = new Paragraph("二級標(biāo)題", secondTitleFont);//設(shè)置行高p1.setLeading(0);//設(shè)置標(biāo)題居中p1.setAlignment(Element.ALIGN_CENTER);//將段落添加到文檔上doc.add(p1);//設(shè)置一個(gè)空的段落,行高為18 什么內(nèi)容都不顯示Paragraph blankRow1 = new Paragraph(18f, " ", FontChinese11);doc.add(blankRow1);//新建表格 列數(shù)為2PdfPTable table1 = new PdfPTable(2);//給表格設(shè)置寬度int width1[] = {80,60};table1.setWidths(width1);//新建單元格String name="霸道的程序猿";String gender="男";//給單元格賦值 每個(gè)單元格為一個(gè)段落,每個(gè)段落的字體為加粗PdfPCell cell11 = new PdfPCell(new Paragraph("姓名: "+name,boldFont));PdfPCell cell12 = new PdfPCell(new Paragraph("性別: "+gender,boldFont));//設(shè)置單元格邊框?yàn)?cell11.setBorder(0);cell12.setBorder(0);table1.addCell(cell11);table1.addCell(cell12);doc.add(table1);PdfPTable table3 = new PdfPTable(2);table3.setWidths(width1);PdfPCell cell15 = new PdfPCell(new Paragraph("博客主頁: https://blog.csdn.net/BADAO_LIUMANG_QIZHI ",boldFont));PdfPCell cell16 = new PdfPCell(new Paragraph("當(dāng)前時(shí)間: "+new Date().toString(),boldFont));cell15.setBorder(0);cell16.setBorder(0);table3.addCell(cell15);table3.addCell(cell16);doc.add(table3);doc.close();}}

具體方法和布局可以參考itext官網(wǎng)或如下

Itext實(shí)現(xiàn)導(dǎo)出PDF常用方法說明:

Itext實(shí)現(xiàn)導(dǎo)出PDF常用方法說明_BADAO_LIUMANG_QIZHI的博客-CSDN博客

4、新建Vue頁面,頁面添加按鈕

<button type="button" style="margin-top: 20px;" @click="btnClick">請求文件流的方式導(dǎo)出PDF</button>

5、按鈕點(diǎn)擊事件

? methods: {btnClick(){???exportPDF().then((res)=>{//導(dǎo)出文件名var filename = '霸道的程序猿';//創(chuàng)建urllet url = window.URL.createObjectURL(res)//創(chuàng)建a標(biāo)簽 并設(shè)置屬性let link = document.createElement('a')link.style.display = 'none'link.href = urllink.setAttribute('download', filename + '.pdf')//添加a標(biāo)簽document.body.appendChild(link)//執(zhí)行下載link.click();//釋放url對象URL.revokeObjectURL(link.href);//釋放a標(biāo)簽document.body.removeChild(link);});},},

點(diǎn)擊事件中調(diào)用了引入的方法exportPDF

import {exportPDF } from "@/api/system/exportPDF";

6、exportPDF.js中方法實(shí)現(xiàn)

import request from '@/utils/request'export function exportPDF() {//以文件流的方式返回?cái)?shù)據(jù)return request({url: '/exportPdf/getPdf',method: 'post',responseType:'blob',}) }

注意這里的

responseType:'blob',

7、完整vue代碼

<template><button type="button" style="margin-top: 20px;" @click="btnClick">請求文件流的方式導(dǎo)出PDF</button> </template><script> import {exportPDF } from "@/api/system/exportPDF"; export default {name: "ExportPDFWithServer",data() {return {};},mounted() {},methods: {btnClick(){???exportPDF().then((res)=>{//導(dǎo)出文件名var filename = '霸道的程序猿';//創(chuàng)建urllet url = window.URL.createObjectURL(res)//創(chuàng)建a標(biāo)簽 并設(shè)置屬性let link = document.createElement('a')link.style.display = 'none'link.href = urllink.setAttribute('download', filename + '.pdf')//添加a標(biāo)簽document.body.appendChild(link)//執(zhí)行下載link.click();//釋放url對象URL.revokeObjectURL(link.href);//釋放a標(biāo)簽document.body.removeChild(link);});},}, }; </script><style scoped></style>

總結(jié)

以上是生活随笔為你收集整理的SpringBoot+Vue+Itext实现前端请求文件流的方式下载PDF的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产色99| 夜夜爽夜夜爽 | 嫩草网站在线观看 | 国产成a人亚洲精v品无码 | 米奇影音 | 美女脱光内衣内裤 | 亚洲免费视频一区二区 | 免费污视频在线观看 | 久久一道本 | 人体内射精一区二区三区 | 日韩91在线 | 女人十八毛片嫩草av | 无码人妻久久一区二区三区不卡 | 国产黄片毛片 | 天天综合在线视频 | 麻豆md0034在线观看 | 亚洲第9页 | 麻豆网 | 六月天综合网 | 日韩国产精品久久 | 影音先锋国产资源 | 狠狠干狠狠搞 | 国产熟女一区二区丰满 | 四虎影视成人 | 成人tv | 毛片无遮挡高清免费观看 | 亚洲一区二区三区久久久成人动漫 | 国产欧美久久久久久 | 一区二区精品在线 | 国产精品一区二区三区四 | 翔田千里一区二区三区av | 中文字幕精品一区二区三区视频 | 日韩成人午夜电影 | 欧美性潮喷xxxxx免费视频看 | av导航网址 | 久久成人一区二区 | 天天摸天天碰天天爽天天弄 | 美国三级视频 | 亚洲av日韩av永久无码下载 | 性免费视频 | 日日干夜夜爱 | 国产明星换脸xxxx色视频 | 国产白浆一区二区 | 天堂а√在线中文在线 | 日韩久久毛片 | 亚洲乱码国产乱码精品精大量 | 免费视频网站在线观看入口 | 亚洲成人第一 | 一本色道久久综合精品婷婷 | 成年人一级黄色片 | 91在线高清| 涩涩涩综合 | 亚洲色图1 | 亚洲av中文无码乱人伦在线观看 | 精品一区二区在线观看 | 久久久永久久久人妻精品麻豆 | 乱图区 | av每日更新在线观看 | 欧美黑人一区二区 | 国产精品一区免费观看 | 午夜视频网站在线观看 | 久久精品tv| 美女人人操 | 成人av免费网站 | 亚洲爆爽av| 打屁股外国网站 | 精品久久人人妻人人做人人 | 海量av| 国产亚洲网站 | 妻色成人网| 夜夜爽天天操 | 亚洲激情成人网 | 久久久免费毛片 | 日韩视频免费观看 | 欧美性猛交ⅹxx | 性欧美视频在线观看 | 欧美激情午夜 | 欧美巨大荫蒂茸毛毛人妖 | 亚洲精品日韩综合观看成人91 | 五月婷视频| www亚洲色图| 欧美成人性色 | 亚洲精品视频大全 | 亚洲视频h| 91ts人妖另类精品系列 | 亚洲视频欧洲视频 | 免费国产a| 成人国产精品蜜柚视频 | 黄色网络在线观看 | 91插视频| www天天干 | 亚洲青涩网 | 91精品国产91久久久久久久久久久久 | 午夜少妇视频 | 亚洲欧美激情在线观看 | 国产精品白嫩极品美女 | 韩日一区二区三区 | a√在线| 麻豆精品免费观看 |