当前位置: 首页 > news >正文

pdf导出实例(itestpdf)

依赖

<!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf --><dependency><groupId>com.itextpdf</groupId><artifactId>itextpdf</artifactId><version>5.5.10</version></dependency>

工具类

package org.jeecg.utils;import com.itextpdf.text.*;
import com.itextpdf.text.pdf.*;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletResponse;
import java.io.ByteArrayOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.*;
import java.util.List;public class PDFUtil {/*** pdf模板导出** @param map 导出结果* @param filePath 空pdf路径,作物前端访问路径* @throws Exception*/public static void creatPdf(Map<String, Object> map, String filePath) throws Exception {try {FileOutputStream fos = new FileOutputStream(filePath);;BaseFont bf = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);// 读取pdf模板路径Resource resource  = new ClassPathResource(String.valueOf(map.get("tempPath")));PdfReader reader = new PdfReader(resource.getURL());ByteArrayOutputStream bos = new ByteArrayOutputStream();PdfStamper stamper = new PdfStamper(reader, bos);stamper.setFormFlattening(true);AcroFields form = stamper.getAcroFields();// 文字类的内容处理Map<String, String> datemap = (Map<String, String>) map.get("dataMap");form.addSubstitutionFont(bf);for (String key : datemap.keySet()) {String value = datemap.get(key);form.setField(key, value);form.setFieldProperty(key,"textsize",9f,null);}// 图片类的内容处理Map<String, String> imgmap = (Map<String, String>) map.get("imgMap");for (String key : imgmap.keySet()) {String value = imgmap.get(key);String imgpath = value;int pageNo = form.getFieldPositions(key).get(0).page;Rectangle signRect = form.getFieldPositions(key).get(0).position;float x = signRect.getLeft();float y = signRect.getBottom();// 根据路径读取图片Image image = Image.getInstance(imgpath);// 获取图片页面PdfContentByte under = stamper.getOverContent(pageNo);// 图片大小自适应image.scaleToFit(signRect.getWidth(), signRect.getHeight());// 添加图片image.setAbsolutePosition(x, y);under.addImage(image);}// 如果为false,生成的PDF文件可以编辑,如果为true,生成的PDF文件不可以编辑stamper.setFormFlattening(false);stamper.close();Document doc = new Document();PdfCopy copy = new PdfCopy(doc, fos);doc.open();int pageNum = reader.getNumberOfPages();for (int i = 1; i <= pageNum; i++) {PdfImportedPage importPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), i);copy.addPage(importPage);}doc.close();fos.close();} catch (IOException e) {System.out.println(e);} catch (DocumentException e) {System.out.println(e);}}}

导出结果数据实例(仅供参考)

package com.fiftheconomic.dataCalculate.service.impl;import com.fiftheconomic.dataCalculate.domain.TjDataCalculateBase;
import com.fiftheconomic.dataCalculate.domain.TjDataCalculateDetail;
import com.fiftheconomic.dataCalculate.domain.resCompenyIndex;
import com.fiftheconomic.dataCalculate.service.IPdfService;
import org.springframework.stereotype.Service;import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.util.*;/*** @Author: 苏子龙* @Date: 2023/08/01/17:00* @Description:*/
@Service
public class PdfServiceImpl implements IPdfService {/*** 123  工业单位填报 124 批发和零售业单位填报 125 住宿和餐饮业单位填报 126 制造业,信息传输、软件和信息技术服务业,科学研究和技术服务业单位填报** @param resMap* @param list* @return*/@Overridepublic Map<String, Object> oneThree(List<resCompenyIndex> resMap, TjDataCalculateBase base, List<TjDataCalculateDetail> list) {List<List<String>> lists = new ArrayList<>();//表格 (一行数据一个list)SimpleDateFormat dft = new SimpleDateFormat("yyyy-MM-dd");Map<String, String> map = new HashMap<>();//文本域for (int i = 0; i < resMap.size(); i++) {if (resMap.get(i).getIndexCode() != null) {if (!map.containsKey(resMap.get(i).getIndexCode())) {map.put(resMap.get(i).getIndexCode(), resMap.get(i).getIndexValue());}}}//添加tj_data_calculate_index基础信息表数据for (int j = 0; j < list.size(); j++) {System.out.println("++++++++" + j);TjDataCalculateDetail data = list.get(j);map.put("name" + j, data.getIndexName());map.put("unit" + j, data.getUnitof());map.put("value" + j, data.getIndexValue());}
//        map.put("name", "无"); //添加tj_data_calculate_index头信息
//        map.put("nameInfo", "无"); //填表人姓名
//        map.put("phoen", "无");//填表人电话
//        map.put("nameBy", "无");//单位负责人
//        map.put("USCI", base.getUSCI());//企业社会信用统一代码
//        map.put("comName", base.getComName());//单位详细名称
//        //添加日期
//        LocalDate now = LocalDate.now();
//        map.put("y", String.valueOf(now.getYear()));
//        map.put("m", String.valueOf(now.getMonthValue()));
//        map.put("d", String.valueOf(now.getDayOfMonth()));
//        map.put("time", String.valueOf(now));//填表人电话Map<String, Object> o = new HashMap<>();String s = base.getIndustryCode();if (s.equals("1")) {o.put("tempPath", "static/pdf/123.pdf");} else if (s.equals("2") || s.equals("3")) {o.put("tempPath", "static/pdf/124.pdf");} else if (s.equals("4") || s.equals("5")) {o.put("tempPath", "static/pdf/125.pdf");} else {o.put("tempPath", "static/pdf/126.pdf");}o.put("dataMap", map);o.put("imgMap", new HashMap<>());Map<String, List<List<String>>> listMap = new HashMap<>();listMap.put("table", lists);o.put("tableList", listMap);return o;}public static void main(String[] args) {LocalDate now = LocalDate.now();System.out.println(now.getYear());System.out.println(now.getMonthValue());System.out.println(now.getDayOfMonth());}}

优化工具包

  public static String creatPdf1(Map<String, Object> map ,OutputStream out,float width[]) throws Exception {BaseFont bf = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);
//        // 输出流
//            String outPutPath = "E:/excel/files/pdf模板导出.pdf";
//            FileOutputStream out = new FileOutputStream(filePath);// 读取pdf模板路径Resource resource = new ClassPathResource(String.valueOf(map.get("tempPath")));PdfReader reader = new PdfReader(resource.getURL());ByteArrayOutputStream bos = new ByteArrayOutputStream();PdfStamper stamper = new PdfStamper(reader, bos);stamper.setFormFlattening(true);AcroFields form = stamper.getAcroFields();// 文字类的内容处理Map<String, String> datemap = (Map<String, String>) map.get("dataMap");form.addSubstitutionFont(bf);for (String key : datemap.keySet()) {String value = datemap.get(key);form.setField(key, value);form.setFieldProperty(key, "textsize", 9f, null);}// 图片类的内容处理Map<String, String> imgmap = (Map<String, String>) map.get("imgMap");for (String key : imgmap.keySet()) {String value = imgmap.get(key);String imgpath = value;int pageNo = form.getFieldPositions(key).get(0).page;Rectangle signRect = form.getFieldPositions(key).get(0).position;float x = signRect.getLeft();float y = signRect.getBottom();// 根据路径读取图片Image image = Image.getInstance(imgpath);// 获取图片页面PdfContentByte under = stamper.getOverContent(pageNo);// 图片大小自适应image.scaleToFit(signRect.getWidth(), signRect.getHeight());// 添加图片image.setAbsolutePosition(x, y);under.addImage(image);}// 表格类Map<String, List<List<String>>> listMap = (Map<String, List<List<String>>>) map.get("tableList");if (listMap != null) {Object[] arr = new Object[]{};if (listMap.containsKey("table1")) {List<List<String>> lists1 = listMap.get("table1");if (lists1.size() > 0) {arr = new Object[]{"table", "table1"};} else {arr = new Object[]{"table"};}}else {arr = new Object[]{"table"};arr = new Object[]{"tableInfo"};}
//            for (Object key : arr) {List<List<String>> lists = listMap.get("table");List<List<String>> listInfo = listMap.get("tableInfo");List<List<String>> listBy = listMap.get("table1");//判断if (listBy!= null && listBy.size()>0) {//遍历数据添加序号for (int i = 0; i < listBy.size(); i++) {List<String> list = listBy.get(i);
//                    List<String> list = listBy.get(0);String data = list.get(0);String on = i + 1 + "   " + data;
//                    String on = 0 + 1 + "   " + data;list.set(0, on);}int pageNo = 0;if (form.getFieldPositions("table1") == null) {pageNo = 0;} else {pageNo = form.getFieldPositions("table1").get(0).page;}PdfContentByte pcb = stamper.getOverContent(pageNo);List<AcroFields.FieldPosition> listAf = form.getFieldPositions("table1");Rectangle signRect = listAf.get(0).position;//表格位置int columnInfo = listBy.get(0).size();int rowInfo = listBy.size();PdfPTable tableInfo = new PdfPTable(columnInfo);
//                    float tatalWidth = signRect.getRight() - signRect.getLeft() - 1;tableInfo.setTotalWidth(width);tableInfo.setLockedWidth(true);tableInfo.setKeepTogether(true);tableInfo.setSplitLate(false);tableInfo.setSplitRows(true);Font FontProve = new Font(bf, 8, 0);//表格数据填写for (int k = 0; k < rowInfo; k++) {List<String> listTo = listBy.get(k);
//                                List<String> listTo = listBy.get(i);for (int j = 0; j < columnInfo; j++) {Paragraph paragraph = new Paragraph(String.valueOf(listTo.get(j)), FontProve);PdfPCell cell = new PdfPCell(paragraph);cell.setBorderWidth(1);cell.setMinimumHeight(1);if (j == 0) {cell.setVerticalAlignment(Element.ALIGN_LEFT);cell.setHorizontalAlignment(Element.ALIGN_LEFT);} else {cell.setVerticalAlignment(Element.ALIGN_CENTER);cell.setHorizontalAlignment(Element.ALIGN_CENTER);}cell.setLeading(0, (float) 1.4);cell.disableBorderSide(15);//隐藏tableInfo.addCell(cell);}}tableInfo.writeSelectedRows(0, -1, signRect.getLeft(), signRect.getTop(), pcb);
//                        }}if (listInfo!= null && listInfo.size()>0) {//遍历数据添加序号for (int i = 0; i < listInfo.size(); i++) {List<String> list = listInfo.get(i);String data = list.get(0);String on = i + 1 +"   " + data ;list.set(0,on);}int pageNo = 0;if (form.getFieldPositions("tableInfo") == null) {pageNo = 0;} else {pageNo = form.getFieldPositions("tableInfo").get(0).page;}PdfContentByte pcb = stamper.getOverContent(pageNo);List<AcroFields.FieldPosition> listAf = form.getFieldPositions("tableInfo");Rectangle signRect = listAf.get(0).position;//表格位置int columnInfo = listInfo.get(0).size();int rowInfo = listInfo.size();PdfPTable tableInfo = new PdfPTable(columnInfo);float tatalWidth = signRect.getRight() - signRect.getLeft() - 1;
//tableInfo.setTotalWidth(tatalWidth);tableInfo.setLockedWidth(true);tableInfo.setKeepTogether(true);tableInfo.setSplitLate(false);tableInfo.setSplitRows(true);Font FontProve = new Font(bf, 8, 0);//表格数据填写for (int i = 0; i < rowInfo; i++) {List<String> list = listInfo.get(i);for (int j = 0; j < columnInfo; j++) {Paragraph paragraph = new Paragraph(String.valueOf(list.get(j)), FontProve);PdfPCell cell = new PdfPCell(paragraph);cell.setBorderWidth(1);cell.setMinimumHeight(1);if (j == 0) {cell.setVerticalAlignment(Element.ALIGN_LEFT);cell.setHorizontalAlignment(Element.ALIGN_LEFT);} else {cell.setVerticalAlignment(Element.ALIGN_CENTER);cell.setHorizontalAlignment(Element.ALIGN_CENTER);}cell.setLeading(0, (float) 1.4);cell.disableBorderSide(15);//隐藏tableInfo.addCell(cell);}}System.out.println(signRect.getLeft());System.out.println(signRect.getTop());System.out.println(pcb);tableInfo.writeSelectedRows(0, -1, signRect.getLeft(), signRect.getTop(), pcb);}if (lists!= null && lists.size()>0) {//遍历数据添加序号for (int i = 0; i < lists.size(); i++) {List<String> list = lists.get(i);String data = list.get(0);String on = i + 1 +"   "+ data ;list.set(0,on);}int pageNo = 0;if (form.getFieldPositions("table") == null) {pageNo = 0;} else {pageNo = form.getFieldPositions("table").get(0).page;}PdfContentByte pcb = stamper.getOverContent(pageNo);List<AcroFields.FieldPosition> listAf = form.getFieldPositions("table");Rectangle signRect = listAf.get(0).position;//表格位置int column = lists.get(0).size();int row = lists.size();PdfPTable table = new PdfPTable(column);
//                    float tatalWidth = signRect.getRight() - signRect.getLeft() - 1;//                table.setTotalWidth(width);table.setLockedWidth(true);table.setKeepTogether(true);table.setSplitLate(false);table.setSplitRows(true);Font FontProve = new Font(bf, 8, 0);//表格数据填写for (int i = 0; i < row; i++) {List<String> list = lists.get(i);for (int j = 0; j < column; j++) {Paragraph paragraph = new Paragraph(String.valueOf(list.get(j)), FontProve);PdfPCell cell = new PdfPCell(paragraph);cell.setBorderWidth(1);cell.setMinimumHeight(1);if (j == 0) {cell.setVerticalAlignment(Element.ALIGN_LEFT);cell.setHorizontalAlignment(Element.ALIGN_LEFT);} else {cell.setVerticalAlignment(Element.ALIGN_CENTER);cell.setHorizontalAlignment(Element.ALIGN_CENTER);}cell.setLeading(0, (float) 1.4);cell.disableBorderSide(15);//隐藏table.addCell(cell);}}table.writeSelectedRows(1, -1, signRect.getLeft(), signRect.getTop(), pcb);}}// 如果为false,生成的PDF文件可以编辑,如果为true,生成的PDF文件不可以编辑stamper.setFormFlattening(true);stamper.close();Document doc = new Document();PdfCopy copy = new PdfCopy(doc, out);doc.open();
//        File file = new File("ruoyi-admin/src/main/resources/static/pdf/111.pdf");
//        File file = new File("D:\\feishu\\yihe\\111.pdf");//本地路径File file = new File("E:\\item\\yihe\\ruoyi-admin\\src\\main\\resources\\static\\pdf\\111.pdf");//线上路径
//        File file = new File("D:\\feishu\\yihe\\111.pdf");PdfCopy copy1 = new PdfCopy(doc, new FileOutputStream(file));doc.open();int pageNum = reader.getNumberOfPages();for (int i = 1; i <= pageNum; i++) {PdfImportedPage importPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), i);copy.addPage(importPage);copy1.addPage(importPage);}
//        String url = AliyunOSSUtil.upload(getMultipartFile(file));
//        System.out.println("url = " + url);doc.close();return "url";}

相关文章:

pdf导出实例(itestpdf)

依赖 <!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf --><dependency><groupId>com.itextpdf</groupId><artifactId>itextpdf</artifactId><version>5.5.10</version></dependency>工具类 package or…...

关于CW32单片机pack包安装 KEIL IAR

CW32 系列微控制器软件开发工具入门 芯片包 1. 下载芯片包 官方下载链接&#xff1a;武汉鑫源半导体 2. 安装芯片包 双击芯片包.pack文件 支持 CW32F 系列的 IDE 支持 CW32F 系列的工具链&#xff1a; • • EWARM v7.70 或更高版本 MDK-ARM v5.17 或更高版本 2.1 EW…...

memcpy内存拷贝函数

目录 一、memcpy内存拷贝函数 注意事项 二、memcpy与strcpy对比 三、模拟实现memcpy函数 四、memcpy函数不能进行两块存在内存重叠的空间的内存拷贝 五、改进my_memcpy函数 一、memcpy内存拷贝函数 头文件&#xff1a;string.h 函数原型&#xff1a;void* memcpy(void* …...

数组模拟堆

文章目录 QuestionIdeasCode Question 维护一个集合&#xff0c;初始时集合为空&#xff0c;支持如下几种操作&#xff1a; I x&#xff0c;插入一个数 x &#xff1b; PM&#xff0c;输出当前集合中的最小值&#xff1b; DM&#xff0c;删除当前集合中的最小值&#xff08;数…...

【深度学习基础知识(一):卷积神经网络CNN基础知识】

深度学习基础知识 深度学习基础知识&#xff08;一&#xff09;&#xff1a;卷积神经网络CNN基础知识 卷积神经网络CNN基础知识 0、目录 1. CNN卷积神经网络的特点 2. 卷积操作基础知识 2.1 卷积操作的概念2.2 卷积操作的种类2.3 卷积操作后特征图谱大小计算公式 3. 池化操…...

Git使用入门

一、Git简介 Git 是一个开源的分布式版本控制系统。 Git版本控制的功能为保存不同版本的代码&#xff0c;保存代码的地方叫做仓库。 每个仓库中有多个分支&#xff0c;每个分支上又有很多节点&#xff0c;每个节点代表一个版本&#xff0c;不同的分支可以进行合并&#xff0…...

电机矢量控制算法和例程

电机矢量控制算法是一种高级的电机控制方法&#xff0c;它通过将电机转子空间矢量转换到旋转坐标系中&#xff0c;并在该坐标系中进行控制来实现对电机的精确控制。下面是对电机矢量控制算法的详细解释&#xff1a; 坐标系变换&#xff1a;电机矢量控制首先将电机转子空间矢量变…...

std::string_view概念原理及应用

概念 使用const string&作为参数是先使用字符串字面量编译器会创建一个临时字符串对象然后创建std::string。 或者一个函数提供char*和const string&参数的两个版本函数&#xff0c;不是优雅的解决方案。 于是需要一个只使用内存不维护内存的类。 原理 在visual s…...

lodash库_.chunk、_.pick、_.omit、_.cloneDeep、_.debounce方法

lodash 模块化、高性能的 JavaScript 实用工具库。官方文档&#xff1a;https://www.lodashjs.com 1.对数组进行分组 _.chunk(array, [size1]) 使用场景&#xff0c;如移动端页面一行能放5个元素&#xff0c;总共7条数据&#xff0c;将一维数组转为二维数组&#xff0c;让一个…...

Java使用FFmpeg对视频文件打标记

免安装 FFmpeg <dependency><groupId>ws.schild</groupId><artifactId>jave-all-deps</artifactId><version>3.0.1</version><exclusions><!-- 排除windows 32位系统 --><exclusion><groupId>ws.sch…...

Redux 学习笔记

在使用 React Redux 前&#xff0c;我们首先了解一下 Redux 的一些基础知识。 Redux 是 JavaScript 应用程序中用于状态管理的容器。它不依赖于任何框架&#xff0c;可以与任何 UI 库和框架一起使用。在应用程序中使用 Redux 时&#xff0c;Redux 是以可预测的方式管理状态。 …...

【Bug】8086汇编学习

文章目录 随笔Bug1、masm编译报错&#xff1a;Illegal use of register2、debug中使用段前缀3、[idata]在编译器中的处理4、push立即数报错5、报错&#xff1a;improper operand type6、程序莫名跳转到未知位置 (doing)7、DOSBox失去响应8、程序运行显示乱码9、程序运行导致DOS…...

JetBrains系列IDE全家桶激活

jetbrains全家桶 正版授权&#xff0c;这里有账号授权的渠道&#xff1a; https://www.mano100.cn/thread-1942-1-1.html 附加授权后的一张图片...

洛谷p1618三连击

import java.util.Scanner; //将 1-9 共9个数分成3组&#xff0c;分别组成3个三位数&#xff0c;且使这3个三位数构成A:B:C的比例&#xff0c;试求出所有满足条件的3个三位数。不满足输出“No!!!”。 public class Main {public static void main(String[] args) {Scanner sc …...

微信公众号h5写一个全局调用微信分享功能

1. 首先先安装依赖 npm install weixin-js-sdk --save 2. app.vue文件 <script> export default { onLaunch: function(e) {}, onShow: function(e) { console.log(App Show页面初始); // 路由参数存缓存的 这是为了防止他…...

聊聊精益需求的产生过程

这是鼎叔的第七十八篇原创文章。行业大牛和刚毕业的小白&#xff0c;都可以进来聊聊。 欢迎关注本公众号《敏捷测试转型》&#xff0c;星标收藏&#xff0c;大量原创思考文章陆续推出。本人新书《无测试组织-测试团队的敏捷转型》​​​​​​​​​​​​​​已出版&#xff…...

Linux - 还不懂 gdb 调试器?(调试软件)

前言 当前&#xff0c;我们可以使用 make/makefile 来程序化执行代码文件&#xff1b;可以使用 gcc/g 等编译器来编译代码&#xff1b;可以使用 vim 编辑器来编写代码&#xff1b;其实在 Linux 当中还有一个工具&#xff0c;可以实现调试工作&#xff0c;这个工具就是 -- gdb。…...

Linux:程序地址空间/虚拟地址等相关概念理解

文章目录 程序地址空间虚拟地址和物理地址地址的转换地址空间是什么&#xff1f; 程序地址空间 在C和C程序中&#xff0c;一直有一个观点是&#xff0c;程序中的各个变量等都会有一定的地址空间&#xff0c;因此才会有诸如取地址&#xff0c;通过地址访问等操作&#xff0c;那…...

Python之爬虫

目录 HTTP请求HTTP响应获得页面响应伪装用户访问打包数据爬取豆瓣top250 HTTP请求 HTTP&#xff1a;HypertextTransferProtcol 超文本传输协议 1、请求行 POST/user/info?new_usertrue HTTP/1.1#资源了路径user/info 查询参数new_usertrue 协议版本HTTP/1.1 2、请求头 Ho…...

打造自己的前端组件库(奶妈版,超详细)

打造自己的前端组件库 demo是开源的&#xff0c;自己上npm 或者 github 上都能搜到 新建vue项目(sass js vue2) vue create yt-ui 修改文件目录(如下) 修改&#xff1a; 1.src 更名 examples; 2. src/components移动到项目最外层&#xff1b;3.vue.config.js更改入口文件 /…...

突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合

强化学习&#xff08;Reinforcement Learning, RL&#xff09;是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程&#xff0c;然后使用强化学习的Actor-Critic机制&#xff08;中文译作“知行互动”机制&#xff09;&#xff0c;逐步迭代求解…...

uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖

在前面的练习中&#xff0c;每个页面需要使用ref&#xff0c;onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入&#xff0c;需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...

HTML 列表、表格、表单

1 列表标签 作用&#xff1a;布局内容排列整齐的区域 列表分类&#xff1a;无序列表、有序列表、定义列表。 例如&#xff1a; 1.1 无序列表 标签&#xff1a;ul 嵌套 li&#xff0c;ul是无序列表&#xff0c;li是列表条目。 注意事项&#xff1a; ul 标签里面只能包裹 li…...

OpenLayers 分屏对比(地图联动)

注&#xff1a;当前使用的是 ol 5.3.0 版本&#xff0c;天地图使用的key请到天地图官网申请&#xff0c;并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能&#xff0c;和卷帘图层不一样的是&#xff0c;分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

【Elasticsearch】Elasticsearch 在大数据生态圈的地位 实践经验

Elasticsearch 在大数据生态圈的地位 & 实践经验 1.Elasticsearch 的优势1.1 Elasticsearch 解决的核心问题1.1.1 传统方案的短板1.1.2 Elasticsearch 的解决方案 1.2 与大数据组件的对比优势1.3 关键优势技术支撑1.4 Elasticsearch 的竞品1.4.1 全文搜索领域1.4.2 日志分析…...

c# 局部函数 定义、功能与示例

C# 局部函数&#xff1a;定义、功能与示例 1. 定义与功能 局部函数&#xff08;Local Function&#xff09;是嵌套在另一个方法内部的私有方法&#xff0c;仅在包含它的方法内可见。 • 作用&#xff1a;封装仅用于当前方法的逻辑&#xff0c;避免污染类作用域&#xff0c;提升…...

Visual Studio Code 扩展

Visual Studio Code 扩展 change-case 大小写转换EmmyLua for VSCode 调试插件Bookmarks 书签 change-case 大小写转换 https://marketplace.visualstudio.com/items?itemNamewmaurer.change-case 选中单词后&#xff0c;命令 changeCase.commands 可预览转换效果 EmmyLua…...

Spring AOP代理对象生成原理

代理对象生成的关键类是【AnnotationAwareAspectJAutoProxyCreator】&#xff0c;这个类继承了【BeanPostProcessor】是一个后置处理器 在bean对象生命周期中初始化时执行【org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization】方法时…...

ThreadLocal 源码

ThreadLocal 源码 此类提供线程局部变量。这些变量不同于它们的普通对应物&#xff0c;因为每个访问一个线程局部变量的线程&#xff08;通过其 get 或 set 方法&#xff09;都有自己独立初始化的变量副本。ThreadLocal 实例通常是类中的私有静态字段&#xff0c;这些类希望将…...